< prev index next >

src/hotspot/share/gc/z/zBarrierSet.hpp

Print this page
*** 48,10 ***
--- 48,16 ---
  
    virtual void on_slowpath_allocation_exit(JavaThread* thread, oop new_obj);
  
    virtual void print_on(outputStream* st) const;
  
+   enum OopCopyCheckStatus {
+     oop_copy_check_ok = 0,         // oop array copy sucessful
+     oop_copy_check_class_cast = 1, // oop array copy failed subtype check (ARRAYCOPY_CHECKCAST)
+     oop_copy_check_null = 2        // oop array copy failed null check (ARRAYCOPY_NOTNULL)
+   };
+ 
    template <DecoratorSet decorators, typename BarrierSetT = ZBarrierSet>
    class AccessBarrier : public BarrierSet::AccessBarrier<decorators, BarrierSetT> {
    private:
      typedef BarrierSet::AccessBarrier<decorators, BarrierSetT> Raw;
  

*** 81,15 ***
      static void no_keep_alive_store_barrier_heap(narrowOop* p)  { unsupported(); }
      static void store_barrier_native_with_healing(narrowOop* p)  { unsupported(); }
      static void store_barrier_native_without_healing(narrowOop* p)  { unsupported(); }
  
      static zaddress oop_copy_one_barriers(zpointer* dst, zpointer* src);
!     static bool oop_copy_one_check_cast(zpointer* dst, zpointer* src, Klass* dst_klass);
!     static void oop_copy_one(zpointer* dst, zpointer* src);
  
!     static bool oop_arraycopy_in_heap_check_cast(zpointer* dst, zpointer* src, size_t length, Klass* dst_klass);
!     static bool oop_arraycopy_in_heap_no_check_cast(zpointer* dst, zpointer* src, size_t length);
  
    public:
      //
      // In heap
      //
--- 87,15 ---
      static void no_keep_alive_store_barrier_heap(narrowOop* p)  { unsupported(); }
      static void store_barrier_native_with_healing(narrowOop* p)  { unsupported(); }
      static void store_barrier_native_without_healing(narrowOop* p)  { unsupported(); }
  
      static zaddress oop_copy_one_barriers(zpointer* dst, zpointer* src);
!     static OopCopyCheckStatus oop_copy_one_check_cast(zpointer* dst, zpointer* src, Klass* dst_klass);
!     static OopCopyCheckStatus oop_copy_one(zpointer* dst, zpointer* src);
  
!     static OopCopyCheckStatus oop_arraycopy_in_heap_check_cast(zpointer* dst, zpointer* src, size_t length, Klass* dst_klass);
!     static OopCopyCheckStatus oop_arraycopy_in_heap_no_check_cast(zpointer* dst, zpointer* src, size_t length);
  
    public:
      //
      // In heap
      //

*** 117,26 ***
      static oop oop_atomic_xchg_in_heap(zpointer* p, oop new_value);
      static oop oop_atomic_xchg_in_heap(oop* p, oop new_value)       { return oop_atomic_xchg_in_heap((zpointer*)p, new_value); }
      static oop oop_atomic_xchg_in_heap(narrowOop* p, oop new_value) { unsupported(); return nullptr; }
      static oop oop_atomic_xchg_in_heap_at(oop base, ptrdiff_t offset, oop new_value);
  
!     static bool oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, zpointer* src_raw,
                                        arrayOop dst_obj, size_t dst_offset_in_bytes, zpointer* dst_raw,
                                        size_t length);
!     static bool oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, oop* src_raw,
                                        arrayOop dst_obj, size_t dst_offset_in_bytes, oop* dst_raw,
                                        size_t length) {
!       return oop_arraycopy_in_heap(src_obj, src_offset_in_bytes, (zpointer*)src_raw,
!                                    dst_obj, dst_offset_in_bytes, (zpointer*)dst_raw,
!                                    length);
      }
!     static bool oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, narrowOop* src_raw,
                                        arrayOop dst_obj, size_t dst_offset_in_bytes, narrowOop* dst_raw,
!                                       size_t length) { unsupported(); return false; }
  
      static void clone_in_heap(oop src, oop dst, size_t size);
  
      //
      // Not in heap
      //
      static oop oop_load_not_in_heap(zpointer* p);
      static oop oop_load_not_in_heap(oop* p);
--- 123,28 ---
      static oop oop_atomic_xchg_in_heap(zpointer* p, oop new_value);
      static oop oop_atomic_xchg_in_heap(oop* p, oop new_value)       { return oop_atomic_xchg_in_heap((zpointer*)p, new_value); }
      static oop oop_atomic_xchg_in_heap(narrowOop* p, oop new_value) { unsupported(); return nullptr; }
      static oop oop_atomic_xchg_in_heap_at(oop base, ptrdiff_t offset, oop new_value);
  
!     static void oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, zpointer* src_raw,
                                        arrayOop dst_obj, size_t dst_offset_in_bytes, zpointer* dst_raw,
                                        size_t length);
!     static void oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, oop* src_raw,
                                        arrayOop dst_obj, size_t dst_offset_in_bytes, oop* dst_raw,
                                        size_t length) {
!       oop_arraycopy_in_heap(src_obj, src_offset_in_bytes, (zpointer*)src_raw,
!                             dst_obj, dst_offset_in_bytes, (zpointer*)dst_raw,
!                             length);
      }
!     static void oop_arraycopy_in_heap(arrayOop src_obj, size_t src_offset_in_bytes, narrowOop* src_raw,
                                        arrayOop dst_obj, size_t dst_offset_in_bytes, narrowOop* dst_raw,
!                                       size_t length) { unsupported(); }
  
      static void clone_in_heap(oop src, oop dst, size_t size);
  
+     static void value_copy_in_heap(void* src, void* dst, InlineKlass* md, LayoutKind lk);
+ 
      //
      // Not in heap
      //
      static oop oop_load_not_in_heap(zpointer* p);
      static oop oop_load_not_in_heap(oop* p);
< prev index next >