From b10833bbf3cd33c6e6a4cf2671f587a27c606ebb Mon Sep 17 00:00:00 2001 From: Feilong Jiang Date: Fri, 22 Apr 2022 23:48:57 +0000 Subject: [PATCH] 8285303: riscv: Incorrect register mask in call_native_base Co-authored-by: Dingli Zhang Reviewed-by: fyang, yadongwang --- src/hotspot/cpu/riscv/macroAssembler_riscv.cpp | 14 ++------------ src/hotspot/cpu/riscv/macroAssembler_riscv.hpp | 7 ------- 2 files changed, 2 insertions(+), 19 deletions(-) diff --git a/src/hotspot/cpu/riscv/macroAssembler_riscv.cpp b/src/hotspot/cpu/riscv/macroAssembler_riscv.cpp index 3710f1c2cb7..c2dd6e844ce 100644 --- a/src/hotspot/cpu/riscv/macroAssembler_riscv.cpp +++ b/src/hotspot/cpu/riscv/macroAssembler_riscv.cpp @@ -569,24 +569,14 @@ void MacroAssembler::emit_static_call_stub() { void MacroAssembler::call_VM_leaf_base(address entry_point, int number_of_arguments, Label *retaddr) { - call_native_base(entry_point, retaddr); -} - -void MacroAssembler::call_native(address entry_point, Register arg_0) { - pass_arg0(this, arg_0); - call_native_base(entry_point); -} - -void MacroAssembler::call_native_base(address entry_point, Label *retaddr) { - Label E, L; int32_t offset = 0; - push_reg(0x80000040, sp); // push << t0 & xmethod >> to sp + push_reg(RegSet::of(t0, xmethod), sp); // push << t0 & xmethod >> to sp movptr_with_offset(t0, entry_point, offset); jalr(x1, t0, offset); if (retaddr != NULL) { bind(*retaddr); } - pop_reg(0x80000040, sp); // pop << t0 & xmethod >> from sp + pop_reg(RegSet::of(t0, xmethod), sp); // pop << t0 & xmethod >> from sp } void MacroAssembler::call_VM_leaf(address entry_point, int number_of_arguments) { diff --git a/src/hotspot/cpu/riscv/macroAssembler_riscv.hpp b/src/hotspot/cpu/riscv/macroAssembler_riscv.hpp index 02ee4479ecc..1e43ab3c061 100644 --- a/src/hotspot/cpu/riscv/macroAssembler_riscv.hpp +++ b/src/hotspot/cpu/riscv/macroAssembler_riscv.hpp @@ -147,13 +147,6 @@ class MacroAssembler: public Assembler { // thread in the default location (xthread) void reset_last_Java_frame(bool clear_fp); - void call_native(address entry_point, - Register arg_0); - void call_native_base( - address entry_point, // the entry point - Label* retaddr = NULL - ); - virtual void call_VM_leaf_base( address entry_point, // the entry point int number_of_arguments, // the number of arguments to pop after the call