8290137: riscv: small refactoring for add_memory_int32/64

Reviewed-by: yadongwang, fjiang, shade
This commit is contained in:
Fei Yang 2022-07-18 13:01:35 +00:00
parent 87340fd540
commit 92067e2003
8 changed files with 87 additions and 47 deletions

View File

@ -50,7 +50,7 @@ void Assembler::add(Register Rd, Register Rn, int64_t increment, Register temp)
} }
} }
void Assembler::addw(Register Rd, Register Rn, int64_t increment, Register temp) { void Assembler::addw(Register Rd, Register Rn, int32_t increment, Register temp) {
if (is_imm_in_range(increment, 12, 0)) { if (is_imm_in_range(increment, 12, 0)) {
addiw(Rd, Rn, increment); addiw(Rd, Rn, increment);
} else { } else {
@ -70,7 +70,7 @@ void Assembler::sub(Register Rd, Register Rn, int64_t decrement, Register temp)
} }
} }
void Assembler::subw(Register Rd, Register Rn, int64_t decrement, Register temp) { void Assembler::subw(Register Rd, Register Rn, int32_t decrement, Register temp) {
if (is_imm_in_range(-decrement, 12, 0)) { if (is_imm_in_range(-decrement, 12, 0)) {
addiw(Rd, Rn, -decrement); addiw(Rd, Rn, -decrement);
} else { } else {
@ -117,30 +117,30 @@ void Assembler::_li(Register Rd, int64_t imm) {
} }
void Assembler::li64(Register Rd, int64_t imm) { void Assembler::li64(Register Rd, int64_t imm) {
// Load upper 32 bits. upper = imm[63:32], but if imm[31] == 1 or // Load upper 32 bits. upper = imm[63:32], but if imm[31] == 1 or
// (imm[31:20] == 0x7ff && imm[19] == 1), upper = imm[63:32] + 1. // (imm[31:20] == 0x7ff && imm[19] == 1), upper = imm[63:32] + 1.
int64_t lower = imm & 0xffffffff; int64_t lower = imm & 0xffffffff;
lower -= ((lower << 44) >> 44); lower -= ((lower << 44) >> 44);
int64_t tmp_imm = ((uint64_t)(imm & 0xffffffff00000000)) + (uint64_t)lower; int64_t tmp_imm = ((uint64_t)(imm & 0xffffffff00000000)) + (uint64_t)lower;
int32_t upper = (tmp_imm - (int32_t)lower) >> 32; int32_t upper = (tmp_imm - (int32_t)lower) >> 32;
// Load upper 32 bits // Load upper 32 bits
int64_t up = upper, lo = upper; int64_t up = upper, lo = upper;
lo = (lo << 52) >> 52; lo = (lo << 52) >> 52;
up -= lo; up -= lo;
up = (int32_t)up; up = (int32_t)up;
lui(Rd, up); lui(Rd, up);
addi(Rd, Rd, lo); addi(Rd, Rd, lo);
// Load the rest 32 bits. // Load the rest 32 bits.
slli(Rd, Rd, 12); slli(Rd, Rd, 12);
addi(Rd, Rd, (int32_t)lower >> 20); addi(Rd, Rd, (int32_t)lower >> 20);
slli(Rd, Rd, 12); slli(Rd, Rd, 12);
lower = ((int32_t)imm << 12) >> 20; lower = ((int32_t)imm << 12) >> 20;
addi(Rd, Rd, lower); addi(Rd, Rd, lower);
slli(Rd, Rd, 8); slli(Rd, Rd, 8);
lower = imm & 0xff; lower = imm & 0xff;
addi(Rd, Rd, lower); addi(Rd, Rd, lower);
} }
void Assembler::li32(Register Rd, int32_t imm) { void Assembler::li32(Register Rd, int32_t imm) {

View File

@ -3066,11 +3066,12 @@ public:
void wrap_label(Register r, Label &L, Register t, load_insn_by_temp insn); void wrap_label(Register r, Label &L, Register t, load_insn_by_temp insn);
void wrap_label(Register r, Label &L, jal_jalr_insn insn); void wrap_label(Register r, Label &L, jal_jalr_insn insn);
// calculate pseudoinstruction // Computational pseudo instructions
void add(Register Rd, Register Rn, int64_t increment, Register temp = t0); void add(Register Rd, Register Rn, int64_t increment, Register temp = t0);
void addw(Register Rd, Register Rn, int64_t increment, Register temp = t0); void addw(Register Rd, Register Rn, int32_t increment, Register temp = t0);
void sub(Register Rd, Register Rn, int64_t decrement, Register temp = t0); void sub(Register Rd, Register Rn, int64_t decrement, Register temp = t0);
void subw(Register Rd, Register Rn, int64_t decrement, Register temp = t0); void subw(Register Rd, Register Rn, int32_t decrement, Register temp = t0);
// RVB pseudo instructions // RVB pseudo instructions
// zero extend word // zero extend word

View File

@ -343,7 +343,7 @@ void ArrayCopyStub::emit_code(LIR_Assembler* ce) {
#ifndef PRODUCT #ifndef PRODUCT
if (PrintC1Statistics) { if (PrintC1Statistics) {
__ la(t1, ExternalAddress((address)&Runtime1::_arraycopy_slowcase_cnt)); __ la(t1, ExternalAddress((address)&Runtime1::_arraycopy_slowcase_cnt));
__ add_memory_int32(Address(t1), 1); __ incrementw(Address(t1));
} }
#endif #endif

View File

@ -57,7 +57,7 @@ void LIR_Assembler::generic_arraycopy(Register src, Register src_pos, Register l
__ mv(c_rarg4, j_rarg4); __ mv(c_rarg4, j_rarg4);
#ifndef PRODUCT #ifndef PRODUCT
if (PrintC1Statistics) { if (PrintC1Statistics) {
__ add_memory_int32(ExternalAddress((address)&Runtime1::_generic_arraycopystub_cnt), 1); __ incrementw(ExternalAddress((address)&Runtime1::_generic_arraycopystub_cnt));
} }
#endif #endif
__ far_call(RuntimeAddress(copyfunc_addr)); __ far_call(RuntimeAddress(copyfunc_addr));
@ -164,7 +164,7 @@ void LIR_Assembler::arraycopy_checkcast(Register src, Register src_pos, Register
if (PrintC1Statistics) { if (PrintC1Statistics) {
Label failed; Label failed;
__ bnez(x10, failed); __ bnez(x10, failed);
__ add_memory_int32(ExternalAddress((address)&Runtime1::_arraycopy_checkcast_cnt), 1); __ incrementw(ExternalAddress((address)&Runtime1::_arraycopy_checkcast_cnt));
__ bind(failed); __ bind(failed);
} }
#endif #endif
@ -173,7 +173,7 @@ void LIR_Assembler::arraycopy_checkcast(Register src, Register src_pos, Register
#ifndef PRODUCT #ifndef PRODUCT
if (PrintC1Statistics) { if (PrintC1Statistics) {
__ add_memory_int32(ExternalAddress((address)&Runtime1::_arraycopy_checkcast_attempt_cnt), 1); __ incrementw(ExternalAddress((address)&Runtime1::_arraycopy_checkcast_attempt_cnt));
} }
#endif #endif
assert_different_registers(dst, dst_pos, length, src_pos, src, x10, t0); assert_different_registers(dst, dst_pos, length, src_pos, src, x10, t0);
@ -324,7 +324,7 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) {
#ifndef PRODUCT #ifndef PRODUCT
if (PrintC1Statistics) { if (PrintC1Statistics) {
__ add_memory_int32(ExternalAddress(Runtime1::arraycopy_count_address(basic_type)), 1); __ incrementw(ExternalAddress(Runtime1::arraycopy_count_address(basic_type)));
} }
#endif #endif
arraycopy_prepare_params(src, src_pos, length, dst, dst_pos, basic_type); arraycopy_prepare_params(src, src_pos, length, dst, dst_pos, basic_type);

View File

@ -1057,7 +1057,7 @@ void LIR_Assembler::type_profile_helper(Register mdo, ciMethodData *md, ciProfil
__ ld(t1, Address(mdo, md->byte_offset_of_slot(data, ReceiverTypeData::receiver_offset(i)))); __ ld(t1, Address(mdo, md->byte_offset_of_slot(data, ReceiverTypeData::receiver_offset(i))));
__ bne(recv, t1, next_test); __ bne(recv, t1, next_test);
Address data_addr(mdo, md->byte_offset_of_slot(data, ReceiverTypeData::receiver_count_offset(i))); Address data_addr(mdo, md->byte_offset_of_slot(data, ReceiverTypeData::receiver_count_offset(i)));
__ add_memory_int64(data_addr, DataLayout::counter_increment); __ increment(data_addr, DataLayout::counter_increment);
__ j(*update_done); __ j(*update_done);
__ bind(next_test); __ bind(next_test);
} }
@ -1567,7 +1567,7 @@ void LIR_Assembler::emit_profile_call(LIR_OpProfileCall* op) {
ciKlass* receiver = vc_data->receiver(i); ciKlass* receiver = vc_data->receiver(i);
if (known_klass->equals(receiver)) { if (known_klass->equals(receiver)) {
Address data_addr(mdo, md->byte_offset_of_slot(data, VirtualCallData::receiver_count_offset(i))); Address data_addr(mdo, md->byte_offset_of_slot(data, VirtualCallData::receiver_count_offset(i)));
__ add_memory_int64(data_addr, DataLayout::counter_increment); __ increment(data_addr, DataLayout::counter_increment);
return; return;
} }
} }
@ -1583,7 +1583,7 @@ void LIR_Assembler::emit_profile_call(LIR_OpProfileCall* op) {
__ mov_metadata(t1, known_klass->constant_encoding()); __ mov_metadata(t1, known_klass->constant_encoding());
__ sd(t1, recv_addr); __ sd(t1, recv_addr);
Address data_addr(mdo, md->byte_offset_of_slot(data, VirtualCallData::receiver_count_offset(i))); Address data_addr(mdo, md->byte_offset_of_slot(data, VirtualCallData::receiver_count_offset(i)));
__ add_memory_int64(data_addr, DataLayout::counter_increment); __ increment(data_addr, DataLayout::counter_increment);
return; return;
} }
} }
@ -1593,13 +1593,13 @@ void LIR_Assembler::emit_profile_call(LIR_OpProfileCall* op) {
type_profile_helper(mdo, md, data, recv, &update_done); type_profile_helper(mdo, md, data, recv, &update_done);
// Receiver did not match any saved receiver and there is no empty row for it. // Receiver did not match any saved receiver and there is no empty row for it.
// Increment total counter to indicate polymorphic case. // Increment total counter to indicate polymorphic case.
__ add_memory_int64(counter_addr, DataLayout::counter_increment); __ increment(counter_addr, DataLayout::counter_increment);
__ bind(update_done); __ bind(update_done);
} }
} else { } else {
// Static call // Static call
__ add_memory_int64(counter_addr, DataLayout::counter_increment); __ increment(counter_addr, DataLayout::counter_increment);
} }
} }

View File

@ -2955,19 +2955,47 @@ Address MacroAssembler::add_memory_helper(const Address dst) {
} }
} }
void MacroAssembler::add_memory_int64(const Address dst, int64_t imm) { void MacroAssembler::increment(const Address dst, int64_t value) {
assert(((dst.getMode() == Address::base_plus_offset &&
is_offset_in_range(dst.offset(), 12)) || is_imm_in_range(value, 12, 0)),
"invalid value and address mode combination");
Address adr = add_memory_helper(dst); Address adr = add_memory_helper(dst);
assert_different_registers(adr.base(), t0); assert(!adr.uses(t0), "invalid dst for address increment");
ld(t0, adr); ld(t0, adr);
addi(t0, t0, imm); add(t0, t0, value, t1);
sd(t0, adr); sd(t0, adr);
} }
void MacroAssembler::add_memory_int32(const Address dst, int32_t imm) { void MacroAssembler::incrementw(const Address dst, int32_t value) {
assert(((dst.getMode() == Address::base_plus_offset &&
is_offset_in_range(dst.offset(), 12)) || is_imm_in_range(value, 12, 0)),
"invalid value and address mode combination");
Address adr = add_memory_helper(dst); Address adr = add_memory_helper(dst);
assert_different_registers(adr.base(), t0); assert(!adr.uses(t0), "invalid dst for address increment");
lwu(t0, adr); lwu(t0, adr);
addiw(t0, t0, imm); addw(t0, t0, value, t1);
sw(t0, adr);
}
void MacroAssembler::decrement(const Address dst, int64_t value) {
assert(((dst.getMode() == Address::base_plus_offset &&
is_offset_in_range(dst.offset(), 12)) || is_imm_in_range(value, 12, 0)),
"invalid value and address mode combination");
Address adr = add_memory_helper(dst);
assert(!adr.uses(t0), "invalid dst for address decrement");
ld(t0, adr);
sub(t0, t0, value, t1);
sd(t0, adr);
}
void MacroAssembler::decrementw(const Address dst, int32_t value) {
assert(((dst.getMode() == Address::base_plus_offset &&
is_offset_in_range(dst.offset(), 12)) || is_imm_in_range(value, 12, 0)),
"invalid value and address mode combination");
Address adr = add_memory_helper(dst);
assert(!adr.uses(t0), "invalid dst for address decrement");
lwu(t0, adr);
subw(t0, t0, value, t1);
sw(t0, adr); sw(t0, adr);
} }

View File

@ -642,8 +642,19 @@ class MacroAssembler: public Assembler {
address trampoline_call(Address entry, CodeBuffer* cbuf = NULL); address trampoline_call(Address entry, CodeBuffer* cbuf = NULL);
address ic_call(address entry, jint method_index = 0); address ic_call(address entry, jint method_index = 0);
void add_memory_int64(const Address dst, int64_t imm); // Support for memory inc/dec
void add_memory_int32(const Address dst, int32_t imm); // n.b. increment/decrement calls with an Address destination will
// need to use a scratch register to load the value to be
// incremented. increment/decrement calls which add or subtract a
// constant value other than sign-extended 12-bit immediate will need
// to use a 2nd scratch register to hold the constant. so, an address
// increment/decrement may trash both t0 and t1.
void increment(const Address dst, int64_t value = 1);
void incrementw(const Address dst, int32_t value = 1);
void decrement(const Address dst, int64_t value = 1);
void decrementw(const Address dst, int32_t value = 1);
void cmpptr(Register src1, Address src2, Label& equal); void cmpptr(Register src1, Address src2, Label& equal);

View File

@ -72,7 +72,7 @@ VtableStub* VtableStubs::create_vtable_stub(int vtable_index) {
#if (!defined(PRODUCT) && defined(COMPILER2)) #if (!defined(PRODUCT) && defined(COMPILER2))
if (CountCompiledCalls) { if (CountCompiledCalls) {
__ la(t2, ExternalAddress((address) SharedRuntime::nof_megamorphic_calls_addr())); __ la(t2, ExternalAddress((address) SharedRuntime::nof_megamorphic_calls_addr()));
__ add_memory_int64(Address(t2), 1); __ increment(Address(t2));
} }
#endif #endif
@ -163,7 +163,7 @@ VtableStub* VtableStubs::create_itable_stub(int itable_index) {
#if (!defined(PRODUCT) && defined(COMPILER2)) #if (!defined(PRODUCT) && defined(COMPILER2))
if (CountCompiledCalls) { if (CountCompiledCalls) {
__ la(x18, ExternalAddress((address) SharedRuntime::nof_megamorphic_calls_addr())); __ la(x18, ExternalAddress((address) SharedRuntime::nof_megamorphic_calls_addr()));
__ add_memory_int64(Address(x18), 1); __ increment(Address(x18));
} }
#endif #endif