23
24 #ifndef SHARE_GC_SHARED_BARRIERSET_INLINE_HPP
25 #define SHARE_GC_SHARED_BARRIERSET_INLINE_HPP
26
27 #include "gc/shared/barrierSet.hpp"
28
29 #include "oops/accessDecorators.hpp"
30 #include "oops/arrayOop.hpp"
31 #include "oops/compressedOops.inline.hpp"
32 #include "oops/objArrayOop.inline.hpp"
33 #include "oops/oop.hpp"
34
35 template <DecoratorSet decorators, typename BarrierSetT>
36 template <typename T>
37 inline OopCopyResult BarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, T* src_raw,
38 arrayOop dst_obj, size_t dst_offset_in_bytes, T* dst_raw,
39 size_t length) {
40 T* src = arrayOopDesc::obj_offset_to_raw(src_obj, src_offset_in_bytes, src_raw);
41 T* dst = arrayOopDesc::obj_offset_to_raw(dst_obj, dst_offset_in_bytes, dst_raw);
42
43 if (!HasDecorator<decorators, ARRAYCOPY_CHECKCAST>::value) {
44 // Covariant, copy without checks
45 Raw::oop_arraycopy(nullptr, 0, src, nullptr, 0, dst, length);
46 return OopCopyResult::ok;
47 }
48
49 // Copy each element with checking casts
50 Klass* const dst_klass = objArrayOop(dst_obj)->element_klass();
51 for (const T* const end = src + length; src < end; src++, dst++) {
52 const T elem = *src;
53 if (!oopDesc::is_instanceof_or_null(CompressedOops::decode(elem), dst_klass)) {
54 return OopCopyResult::failed_check_class_cast;
55 }
56 *dst = elem;
57 }
58
59 return OopCopyResult::ok;
60 }
61
62 #endif // SHARE_GC_SHARED_BARRIERSET_INLINE_HPP
|
23
24 #ifndef SHARE_GC_SHARED_BARRIERSET_INLINE_HPP
25 #define SHARE_GC_SHARED_BARRIERSET_INLINE_HPP
26
27 #include "gc/shared/barrierSet.hpp"
28
29 #include "oops/accessDecorators.hpp"
30 #include "oops/arrayOop.hpp"
31 #include "oops/compressedOops.inline.hpp"
32 #include "oops/objArrayOop.inline.hpp"
33 #include "oops/oop.hpp"
34
35 template <DecoratorSet decorators, typename BarrierSetT>
36 template <typename T>
37 inline OopCopyResult BarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, T* src_raw,
38 arrayOop dst_obj, size_t dst_offset_in_bytes, T* dst_raw,
39 size_t length) {
40 T* src = arrayOopDesc::obj_offset_to_raw(src_obj, src_offset_in_bytes, src_raw);
41 T* dst = arrayOopDesc::obj_offset_to_raw(dst_obj, dst_offset_in_bytes, dst_raw);
42
43 if ((!HasDecorator<decorators, ARRAYCOPY_CHECKCAST>::value) &&
44 (!HasDecorator<decorators, ARRAYCOPY_NOTNULL>::value)) {
45 // Covariant, copy without checks
46 Raw::oop_arraycopy(nullptr, 0, src, nullptr, 0, dst, length);
47
48 return OopCopyResult::ok;
49 }
50
51 // Copy each element with checking casts
52 Klass* const dst_klass = objArrayOop(dst_obj)->element_klass();
53 for (const T* const end = src + length; src < end; src++, dst++) {
54 const T elem = *src;
55 if (HasDecorator<decorators, ARRAYCOPY_NOTNULL>::value && CompressedOops::is_null(elem)) {
56 return OopCopyResult::failed_check_null;
57 }
58 if (HasDecorator<decorators, ARRAYCOPY_CHECKCAST>::value &&
59 !oopDesc::is_instanceof_or_null(CompressedOops::decode(elem), dst_klass)) {
60 return OopCopyResult::failed_check_class_cast;
61 }
62 *dst = elem;
63 }
64
65 return OopCopyResult::ok;
66 }
67
68 #endif // SHARE_GC_SHARED_BARRIERSET_INLINE_HPP
|