From 6be7841937944364d365b33a795e7aa89dac2c58 Mon Sep 17 00:00:00 2001 From: Roman Kennke Date: Thu, 15 Feb 2018 23:45:15 +0100 Subject: [PATCH] 8197999: Accessors in typeArrayOopDesc should use new Access API Reviewed-by: eosterlund, pliden --- src/hotspot/share/ci/ciArray.cpp | 2 +- src/hotspot/share/ci/ciTypeArray.cpp | 1 + .../share/classfile/javaAssertions.cpp | 1 + src/hotspot/share/classfile/javaClasses.cpp | 2 +- .../share/jvmci/jvmciCodeInstaller.cpp | 1 + src/hotspot/share/jvmci/jvmciCompilerToVM.cpp | 1 + src/hotspot/share/oops/annotations.cpp | 1 + src/hotspot/share/oops/constantPool.cpp | 1 + src/hotspot/share/oops/typeArrayOop.hpp | 64 +++++----- .../share/oops/typeArrayOop.inline.hpp | 115 ++++++++++++++++++ src/hotspot/share/prims/jni.cpp | 2 +- src/hotspot/share/prims/jvmtiTagMap.cpp | 1 + src/hotspot/share/prims/methodHandles.cpp | 1 + src/hotspot/share/prims/unsafe.cpp | 1 + src/hotspot/share/prims/whitebox.cpp | 1 + src/hotspot/share/runtime/deoptimization.cpp | 1 + src/hotspot/share/runtime/reflection.cpp | 1 + src/hotspot/share/runtime/thread.cpp | 1 + src/hotspot/share/services/heapDumper.cpp | 1 + src/hotspot/share/services/management.cpp | 1 + 20 files changed, 161 insertions(+), 39 deletions(-) diff --git a/src/hotspot/share/ci/ciArray.cpp b/src/hotspot/share/ci/ciArray.cpp index 2c9b44a2042..8cd5ddd6af7 100644 --- a/src/hotspot/share/ci/ciArray.cpp +++ b/src/hotspot/share/ci/ciArray.cpp @@ -30,7 +30,7 @@ #include "ci/ciUtilities.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" -#include "oops/typeArrayOop.hpp" +#include "oops/typeArrayOop.inline.hpp" // ciArray // diff --git a/src/hotspot/share/ci/ciTypeArray.cpp b/src/hotspot/share/ci/ciTypeArray.cpp index f85379fdb43..60814a261eb 100644 --- a/src/hotspot/share/ci/ciTypeArray.cpp +++ b/src/hotspot/share/ci/ciTypeArray.cpp @@ -25,6 +25,7 @@ #include "precompiled.hpp" #include "ci/ciTypeArray.hpp" #include "ci/ciUtilities.hpp" +#include "oops/typeArrayOop.inline.hpp" // ciTypeArray // diff --git a/src/hotspot/share/classfile/javaAssertions.cpp b/src/hotspot/share/classfile/javaAssertions.cpp index 790c420e2e0..1bc6e7c460a 100644 --- a/src/hotspot/share/classfile/javaAssertions.cpp +++ b/src/hotspot/share/classfile/javaAssertions.cpp @@ -31,6 +31,7 @@ #include "memory/oopFactory.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "runtime/handles.inline.hpp" bool JavaAssertions::_userDefault = false; diff --git a/src/hotspot/share/classfile/javaClasses.cpp b/src/hotspot/share/classfile/javaClasses.cpp index 5fdb0b10ea0..040d80cc067 100644 --- a/src/hotspot/share/classfile/javaClasses.cpp +++ b/src/hotspot/share/classfile/javaClasses.cpp @@ -46,7 +46,7 @@ #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" #include "oops/symbol.hpp" -#include "oops/typeArrayOop.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "prims/resolvedMethodTable.hpp" #include "runtime/fieldDescriptor.hpp" #include "runtime/handles.inline.hpp" diff --git a/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp b/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp index fa7f375ad98..4a99e876622 100644 --- a/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp +++ b/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp @@ -36,6 +36,7 @@ #include "jvmci/jvmciRuntime.hpp" #include "oops/oop.inline.hpp" #include "oops/objArrayOop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "runtime/javaCalls.hpp" #include "runtime/safepointMechanism.inline.hpp" #include "utilities/align.hpp" diff --git a/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp b/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp index 996049476ce..82d31d6f0c1 100644 --- a/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp +++ b/src/hotspot/share/jvmci/jvmciCompilerToVM.cpp @@ -32,6 +32,7 @@ #include "oops/fieldStreams.hpp" #include "oops/oop.inline.hpp" #include "oops/objArrayOop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "runtime/fieldDescriptor.hpp" #include "runtime/javaCalls.hpp" #include "jvmci/jvmciRuntime.hpp" diff --git a/src/hotspot/share/oops/annotations.cpp b/src/hotspot/share/oops/annotations.cpp index 7b6af287f39..95c060f680c 100644 --- a/src/hotspot/share/oops/annotations.cpp +++ b/src/hotspot/share/oops/annotations.cpp @@ -31,6 +31,7 @@ #include "memory/oopFactory.hpp" #include "oops/annotations.hpp" #include "oops/instanceKlass.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "utilities/ostream.hpp" // Allocate annotations in metadata area diff --git a/src/hotspot/share/oops/constantPool.cpp b/src/hotspot/share/oops/constantPool.cpp index 9f33416bc95..3059883bab9 100644 --- a/src/hotspot/share/oops/constantPool.cpp +++ b/src/hotspot/share/oops/constantPool.cpp @@ -43,6 +43,7 @@ #include "oops/objArrayKlass.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "runtime/fieldType.hpp" #include "runtime/init.hpp" #include "runtime/javaCalls.hpp" diff --git a/src/hotspot/share/oops/typeArrayOop.hpp b/src/hotspot/share/oops/typeArrayOop.hpp index df3884da816..998de9e5ff2 100644 --- a/src/hotspot/share/oops/typeArrayOop.hpp +++ b/src/hotspot/share/oops/typeArrayOop.hpp @@ -34,6 +34,12 @@ #include class typeArrayOopDesc : public arrayOopDesc { +private: + template + static ptrdiff_t element_offset(BasicType bt, int index) { + return arrayOopDesc::base_offset_in_bytes(bt) + sizeof(T) * index; + } + protected: jchar* char_base() const { return (jchar*) base(T_CHAR); } jboolean* bool_base() const { return (jboolean*)base(T_BOOLEAN); } @@ -92,52 +98,38 @@ class typeArrayOopDesc : public arrayOopDesc { return &double_base()[which]; } - jbyte byte_at(int which) const { return *byte_at_addr(which); } - void byte_at_put(int which, jbyte contents) { *byte_at_addr(which) = contents; } + jbyte byte_at(int which) const; + void byte_at_put(int which, jbyte contents); - jboolean bool_at(int which) const { return *bool_at_addr(which); } - void bool_at_put(int which, jboolean contents) { *bool_at_addr(which) = (((jint)contents) & 1); } + jboolean bool_at(int which) const; + void bool_at_put(int which, jboolean contents); - jchar char_at(int which) const { return *char_at_addr(which); } - void char_at_put(int which, jchar contents) { *char_at_addr(which) = contents; } + jchar char_at(int which) const; + void char_at_put(int which, jchar contents); - jint int_at(int which) const { return *int_at_addr(which); } - void int_at_put(int which, jint contents) { *int_at_addr(which) = contents; } + jint int_at(int which) const; + void int_at_put(int which, jint contents); - jshort short_at(int which) const { return *short_at_addr(which); } - void short_at_put(int which, jshort contents) { *short_at_addr(which) = contents; } + jshort short_at(int which) const; + void short_at_put(int which, jshort contents); - jushort ushort_at(int which) const { return *ushort_at_addr(which); } - void ushort_at_put(int which, jushort contents) { *ushort_at_addr(which) = contents; } + jushort ushort_at(int which) const; + void ushort_at_put(int which, jushort contents); - jlong long_at(int which) const { return *long_at_addr(which); } - void long_at_put(int which, jlong contents) { *long_at_addr(which) = contents; } + jlong long_at(int which) const; + void long_at_put(int which, jlong contents); - jfloat float_at(int which) const { return *float_at_addr(which); } - void float_at_put(int which, jfloat contents) { *float_at_addr(which) = contents; } + jfloat float_at(int which) const; + void float_at_put(int which, jfloat contents); - jdouble double_at(int which) const { return *double_at_addr(which); } - void double_at_put(int which, jdouble contents) { *double_at_addr(which) = contents; } + jdouble double_at(int which) const; + void double_at_put(int which, jdouble contents); - jbyte byte_at_acquire(int which) const { return OrderAccess::load_acquire(byte_at_addr(which)); } - void release_byte_at_put(int which, jbyte contents) { OrderAccess::release_store(byte_at_addr(which), contents); } + jbyte byte_at_acquire(int which) const; + void release_byte_at_put(int which, jbyte contents); - // Java thinks Symbol arrays are just arrays of either long or int, since - // there doesn't seem to be T_ADDRESS, so this is a bit of unfortunate - // casting -#ifdef _LP64 - Symbol* symbol_at(int which) const { - return (Symbol*)*long_at_addr(which); } - void symbol_at_put(int which, Symbol* contents) { - *long_at_addr(which) = (jlong)contents; - } -#else - Symbol* symbol_at(int which) const { - return (Symbol*)*int_at_addr(which); } - void symbol_at_put(int which, Symbol* contents) { - *int_at_addr(which) = (int)contents; - } -#endif // _LP64 + Symbol* symbol_at(int which) const; + void symbol_at_put(int which, Symbol* contents); // Sizing diff --git a/src/hotspot/share/oops/typeArrayOop.inline.hpp b/src/hotspot/share/oops/typeArrayOop.inline.hpp index 679993db822..a935d6dc637 100644 --- a/src/hotspot/share/oops/typeArrayOop.inline.hpp +++ b/src/hotspot/share/oops/typeArrayOop.inline.hpp @@ -25,6 +25,7 @@ #ifndef SHARE_VM_OOPS_TYPEARRAYOOP_INLINE_HPP #define SHARE_VM_OOPS_TYPEARRAYOOP_INLINE_HPP +#include "oops/access.inline.hpp" #include "oops/oop.inline.hpp" #include "oops/typeArrayOop.hpp" @@ -33,4 +34,118 @@ int typeArrayOopDesc::object_size() { return object_size(tk->layout_helper(), length()); } +inline jbyte typeArrayOopDesc::byte_at(int which) const { + ptrdiff_t offset = element_offset(T_BYTE, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::byte_at_put(int which, jbyte contents) { + ptrdiff_t offset = element_offset(T_BYTE, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jboolean typeArrayOopDesc::bool_at(int which) const { + ptrdiff_t offset = element_offset(T_BOOLEAN, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::bool_at_put(int which, jboolean contents) { + ptrdiff_t offset = element_offset(T_BOOLEAN, which); + HeapAccess::store_at(as_oop(), offset, ((jint)contents) & 1); +} + +inline jchar typeArrayOopDesc::char_at(int which) const { + ptrdiff_t offset = element_offset(T_CHAR, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::char_at_put(int which, jchar contents) { + ptrdiff_t offset = element_offset(T_CHAR, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jint typeArrayOopDesc::int_at(int which) const { + ptrdiff_t offset = element_offset(T_INT, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::int_at_put(int which, jint contents) { + ptrdiff_t offset = element_offset(T_INT, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jshort typeArrayOopDesc::short_at(int which) const { + ptrdiff_t offset = element_offset(T_SHORT, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::short_at_put(int which, jshort contents) { + ptrdiff_t offset = element_offset(T_BOOLEAN, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jushort typeArrayOopDesc::ushort_at(int which) const { + ptrdiff_t offset = element_offset(T_SHORT, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::ushort_at_put(int which, jushort contents) { + ptrdiff_t offset = element_offset(T_SHORT, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jlong typeArrayOopDesc::long_at(int which) const { + ptrdiff_t offset = element_offset(T_LONG, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::long_at_put(int which, jlong contents) { + ptrdiff_t offset = element_offset(T_LONG, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jfloat typeArrayOopDesc::float_at(int which) const { + ptrdiff_t offset = element_offset(T_FLOAT, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::float_at_put(int which, jfloat contents) { + ptrdiff_t offset = element_offset(T_FLOAT, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jdouble typeArrayOopDesc::double_at(int which) const { + ptrdiff_t offset = element_offset(T_DOUBLE, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::double_at_put(int which, jdouble contents) { + ptrdiff_t offset = element_offset(T_DOUBLE, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +inline jbyte typeArrayOopDesc::byte_at_acquire(int which) const { + ptrdiff_t offset = element_offset(T_BYTE, which); + return HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::release_byte_at_put(int which, jbyte contents) { + ptrdiff_t offset = element_offset(T_BYTE, which); + HeapAccess::store_at(as_oop(), offset, contents); +} + +// Java thinks Symbol arrays are just arrays of either long or int, since +// there doesn't seem to be T_ADDRESS, so this is a bit of unfortunate +// casting +#ifdef _LP64 +inline Symbol* typeArrayOopDesc::symbol_at(int which) const { + ptrdiff_t offset = element_offset(T_LONG, which); + return (Symbol*)(jlong) HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::symbol_at_put(int which, Symbol* contents) { + ptrdiff_t offset = element_offset(T_LONG, which); + HeapAccess::store_at(as_oop(), offset, (jlong)contents); +} +#else +inline Symbol* typeArrayOopDesc::symbol_at(int which) const { + ptrdiff_t offset = element_offset(T_INT, which); + return (Symbol*)(jint) HeapAccess::load_at(as_oop(), offset); +} +inline void typeArrayOopDesc::symbol_at_put(int which, Symbol* contents) { + ptrdiff_t offset = element_offset(T_INT, which); + HeapAccess::store_at(as_oop(), offset, (jint)contents); +} +#endif // _LP64 + + #endif // SHARE_VM_OOPS_TYPEARRAYOOP_INLINE_HPP diff --git a/src/hotspot/share/prims/jni.cpp b/src/hotspot/share/prims/jni.cpp index 627322d134b..9d873ba0875 100644 --- a/src/hotspot/share/prims/jni.cpp +++ b/src/hotspot/share/prims/jni.cpp @@ -53,7 +53,7 @@ #include "oops/oop.inline.hpp" #include "oops/symbol.hpp" #include "oops/typeArrayKlass.hpp" -#include "oops/typeArrayOop.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "prims/jniCheck.hpp" #include "prims/jniExport.hpp" #include "prims/jniFastGetField.hpp" diff --git a/src/hotspot/share/prims/jvmtiTagMap.cpp b/src/hotspot/share/prims/jvmtiTagMap.cpp index 6980b8365cc..570a411d9dc 100644 --- a/src/hotspot/share/prims/jvmtiTagMap.cpp +++ b/src/hotspot/share/prims/jvmtiTagMap.cpp @@ -35,6 +35,7 @@ #include "oops/objArrayKlass.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "prims/jvmtiEventController.hpp" #include "prims/jvmtiEventController.inline.hpp" #include "prims/jvmtiExport.hpp" diff --git a/src/hotspot/share/prims/methodHandles.cpp b/src/hotspot/share/prims/methodHandles.cpp index 64dace47b4b..9a77c40e26e 100644 --- a/src/hotspot/share/prims/methodHandles.cpp +++ b/src/hotspot/share/prims/methodHandles.cpp @@ -36,6 +36,7 @@ #include "memory/resourceArea.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "prims/methodHandles.hpp" #include "runtime/compilationPolicy.hpp" #include "runtime/javaCalls.hpp" diff --git a/src/hotspot/share/prims/unsafe.cpp b/src/hotspot/share/prims/unsafe.cpp index a8d13138507..2fbfc055300 100644 --- a/src/hotspot/share/prims/unsafe.cpp +++ b/src/hotspot/share/prims/unsafe.cpp @@ -33,6 +33,7 @@ #include "oops/fieldStreams.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "prims/unsafe.hpp" #include "runtime/atomic.hpp" #include "runtime/globals.hpp" diff --git a/src/hotspot/share/prims/whitebox.cpp b/src/hotspot/share/prims/whitebox.cpp index d131d83740a..920517ff84f 100644 --- a/src/hotspot/share/prims/whitebox.cpp +++ b/src/hotspot/share/prims/whitebox.cpp @@ -44,6 +44,7 @@ #include "oops/objArrayKlass.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "prims/wbtestmethods/parserTests.hpp" #include "prims/whitebox.hpp" #include "runtime/arguments.hpp" diff --git a/src/hotspot/share/runtime/deoptimization.cpp b/src/hotspot/share/runtime/deoptimization.cpp index c61f41d2933..7ba85c298e2 100644 --- a/src/hotspot/share/runtime/deoptimization.cpp +++ b/src/hotspot/share/runtime/deoptimization.cpp @@ -40,6 +40,7 @@ #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" #include "oops/fieldStreams.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "oops/verifyOopClosure.hpp" #include "prims/jvmtiThreadState.hpp" #include "runtime/biasedLocking.hpp" diff --git a/src/hotspot/share/runtime/reflection.cpp b/src/hotspot/share/runtime/reflection.cpp index 8fa6e9cb5ab..4933afec18e 100644 --- a/src/hotspot/share/runtime/reflection.cpp +++ b/src/hotspot/share/runtime/reflection.cpp @@ -39,6 +39,7 @@ #include "oops/objArrayKlass.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "prims/jvmtiExport.hpp" #include "runtime/arguments.hpp" #include "runtime/handles.inline.hpp" diff --git a/src/hotspot/share/runtime/thread.cpp b/src/hotspot/share/runtime/thread.cpp index 840fe145e52..f02505cba2c 100644 --- a/src/hotspot/share/runtime/thread.cpp +++ b/src/hotspot/share/runtime/thread.cpp @@ -51,6 +51,7 @@ #include "oops/objArrayOop.hpp" #include "oops/oop.inline.hpp" #include "oops/symbol.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "oops/verifyOopClosure.hpp" #include "prims/jvm_misc.hpp" #include "prims/jvmtiExport.hpp" diff --git a/src/hotspot/share/services/heapDumper.cpp b/src/hotspot/share/services/heapDumper.cpp index a920f222b49..ef53af460df 100644 --- a/src/hotspot/share/services/heapDumper.cpp +++ b/src/hotspot/share/services/heapDumper.cpp @@ -35,6 +35,7 @@ #include "oops/objArrayKlass.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "runtime/javaCalls.hpp" #include "runtime/jniHandles.hpp" #include "runtime/os.hpp" diff --git a/src/hotspot/share/services/management.cpp b/src/hotspot/share/services/management.cpp index 8273fec1b2e..04d812abeea 100644 --- a/src/hotspot/share/services/management.cpp +++ b/src/hotspot/share/services/management.cpp @@ -33,6 +33,7 @@ #include "oops/objArrayKlass.hpp" #include "oops/objArrayOop.inline.hpp" #include "oops/oop.inline.hpp" +#include "oops/typeArrayOop.inline.hpp" #include "runtime/arguments.hpp" #include "runtime/globals.hpp" #include "runtime/handles.inline.hpp"