From 224a30f12ce27257af94e2607c53e5f59ac2bd0f Mon Sep 17 00:00:00 2001 From: Boris Ulasevich Date: Sat, 19 Sep 2020 07:47:37 +0000 Subject: [PATCH] 8252311: AArch64: save two words in itable lookup stub Reviewed-by: adinn, aph --- .../cpu/aarch64/macroAssembler_aarch64.cpp | 33 ++++++++----------- 1 file changed, 14 insertions(+), 19 deletions(-) diff --git a/src/hotspot/cpu/aarch64/macroAssembler_aarch64.cpp b/src/hotspot/cpu/aarch64/macroAssembler_aarch64.cpp index 80953cbb20f..e904282a573 100644 --- a/src/hotspot/cpu/aarch64/macroAssembler_aarch64.cpp +++ b/src/hotspot/cpu/aarch64/macroAssembler_aarch64.cpp @@ -1004,27 +1004,22 @@ void MacroAssembler::lookup_interface_method(Register recv_klass, // } Label search, found_method; - for (int peel = 1; peel >= 0; peel--) { - ldr(method_result, Address(scan_temp, itableOffsetEntry::interface_offset_in_bytes())); - cmp(intf_klass, method_result); - - if (peel) { - br(Assembler::EQ, found_method); - } else { - br(Assembler::NE, search); - // (invert the test to fall through to found_method...) - } - - if (!peel) break; - - bind(search); - - // Check that the previous entry is non-null. A null entry means that - // the receiver class doesn't implement the interface, and wasn't the - // same as when the caller was compiled. - cbz(method_result, L_no_such_interface); + ldr(method_result, Address(scan_temp, itableOffsetEntry::interface_offset_in_bytes())); + cmp(intf_klass, method_result); + br(Assembler::EQ, found_method); + bind(search); + // Check that the previous entry is non-null. A null entry means that + // the receiver class doesn't implement the interface, and wasn't the + // same as when the caller was compiled. + cbz(method_result, L_no_such_interface); + if (itableOffsetEntry::interface_offset_in_bytes() != 0) { add(scan_temp, scan_temp, scan_step); + ldr(method_result, Address(scan_temp, itableOffsetEntry::interface_offset_in_bytes())); + } else { + ldr(method_result, Address(pre(scan_temp, scan_step))); } + cmp(intf_klass, method_result); + br(Assembler::NE, search); bind(found_method);