< prev index next >
src/hotspot/share/oops/typeArrayKlass.cpp
Print this page
rev 48688 : Access barriers for arraycopy
*** 147,165 ****
}
// Check zero copy
if (length == 0)
return;
- s = arrayOop(BarrierSet::barrier_set()->read_barrier(s));
- d = arrayOop(BarrierSet::barrier_set()->write_barrier(d));
-
// This is an attempt to make the copy_array fast.
int l2es = log2_element_size();
int ihs = array_header_in_bytes() / wordSize;
char* src = (char*) ((oop*)s + ihs) + ((size_t)src_pos << l2es);
char* dst = (char*) ((oop*)d + ihs) + ((size_t)dst_pos << l2es);
! Copy::conjoint_memory_atomic(src, dst, (size_t)length << l2es);
}
// create a klass of array holding typeArrays
Klass* TypeArrayKlass::array_klass_impl(bool or_null, int n, TRAPS) {
--- 147,162 ----
}
// Check zero copy
if (length == 0)
return;
// This is an attempt to make the copy_array fast.
int l2es = log2_element_size();
int ihs = array_header_in_bytes() / wordSize;
char* src = (char*) ((oop*)s + ihs) + ((size_t)src_pos << l2es);
char* dst = (char*) ((oop*)d + ihs) + ((size_t)dst_pos << l2es);
! HeapAccess<>::arraycopy(s, d, src, dst, (size_t)length << l2es);
}
// create a klass of array holding typeArrays
Klass* TypeArrayKlass::array_klass_impl(bool or_null, int n, TRAPS) {
< prev index next >