--- a/src/hotspot/cpu/aarch64/macroAssembler_aarch64.cpp Fri Jun 28 11:26:07 2019 +0100
+++ b/src/hotspot/cpu/aarch64/macroAssembler_aarch64.cpp Fri Jun 28 17:10:22 2019 +0300
@@ -1307,6 +1307,35 @@
bind(L_fallthrough);
}
+void MacroAssembler::clinit_barrier(Register klass, Register scratch, Label* L_fast_path, Label* L_slow_path) {
+ assert(L_fast_path != NULL || L_slow_path != NULL, "at least one is required");
+ assert_different_registers(klass, rthread, scratch);
+
+ Label L_fallthrough, L_tmp;
+ if (L_fast_path == NULL) {
+ L_fast_path = &L_fallthrough;
+ } else if (L_slow_path == NULL) {
+ L_slow_path = &L_fallthrough;
+ }
+ // Fast path check: class is fully initialized
+ ldrb(scratch, Address(klass, InstanceKlass::init_state_offset()));
+ subs(zr, scratch, InstanceKlass::fully_initialized);
+ br(Assembler::EQ, *L_fast_path);
+
+ // Fast path check: current thread is initializer thread
+ ldr(scratch, Address(klass, InstanceKlass::init_thread_offset()));
+ cmp(rthread, scratch);
+
+ if (L_slow_path == &L_fallthrough) {
+ br(Assembler::EQ, *L_fast_path);
+ bind(*L_slow_path);
+ } else if (L_fast_path == &L_fallthrough) {
+ br(Assembler::NE, *L_slow_path);
+ bind(*L_fast_path);
+ } else {
+ Unimplemented();
+ }
+}
void MacroAssembler::verify_oop(Register reg, const char* s) {
if (!VerifyOops) return;
@@ -3683,6 +3712,12 @@
bs->obj_equals(this, obj1, obj2);
}
+void MacroAssembler::load_method_holder(Register holder, Register method) {
+ ldr(holder, Address(method, Method::const_offset())); // ConstMethod*
+ ldr(holder, Address(holder, ConstMethod::constants_offset())); // ConstantPool*
+ ldr(holder, Address(holder, ConstantPool::pool_holder_offset_in_bytes())); // InstanceKlass*
+}
+
void MacroAssembler::load_klass(Register dst, Register src) {
if (UseCompressedClassPointers) {
ldrw(dst, Address(src, oopDesc::klass_offset_in_bytes()));