提交 f7c8be70 编写于 作者: G goetz

8027968: Adapt PPC to 8024927: Nashorn performance regression with CompressedOops

Reviewed-by: coleenp, kvn
上级 c97d9763
...@@ -2382,10 +2382,12 @@ void MacroAssembler::get_vm_result_2(Register metadata_result) { ...@@ -2382,10 +2382,12 @@ void MacroAssembler::get_vm_result_2(Register metadata_result) {
void MacroAssembler::encode_klass_not_null(Register dst, Register src) { void MacroAssembler::encode_klass_not_null(Register dst, Register src) {
if (src == noreg) src = dst; if (src == noreg) src = dst;
assert(Universe::narrow_klass_base() != NULL, "Base should be initialized"); if (Universe::narrow_klass_base() != 0) {
load_const(R0, Universe::narrow_klass_base()); load_const(R0, Universe::narrow_klass_base());
sub(dst, src, R0); sub(dst, src, R0);
if (Universe::narrow_klass_shift() != 0) { }
if (Universe::narrow_klass_shift() != 0 ||
Universe::narrow_klass_base() == 0 && src != dst) { // Move required.
srdi(dst, src, Universe::narrow_klass_shift()); srdi(dst, src, Universe::narrow_klass_shift());
} }
} }
...@@ -2399,16 +2401,25 @@ void MacroAssembler::store_klass(Register dst_oop, Register klass, Register ck) ...@@ -2399,16 +2401,25 @@ void MacroAssembler::store_klass(Register dst_oop, Register klass, Register ck)
} }
} }
int MacroAssembler::instr_size_for_decode_klass_not_null() {
if (!UseCompressedClassPointers) return 0;
int num_instrs = 1; // shift or move
if (Universe::narrow_klass_base() != 0) num_instrs = 7; // shift + load const + add
return num_instrs * BytesPerInstWord;
}
void MacroAssembler::decode_klass_not_null(Register dst, Register src) { void MacroAssembler::decode_klass_not_null(Register dst, Register src) {
if (src == noreg) src = dst; if (src == noreg) src = dst;
Register shifted_src = src; Register shifted_src = src;
assert(Universe::narrow_klass_base() != NULL, "Base should be initialized"); if (Universe::narrow_klass_shift() != 0 ||
if (Universe::narrow_klass_shift() != 0) { Universe::narrow_klass_base() == 0 && src != dst) { // Move required.
shifted_src = dst; shifted_src = dst;
sldi(shifted_src, src, Universe::narrow_klass_shift()); sldi(shifted_src, src, Universe::narrow_klass_shift());
} }
load_const(R0, Universe::narrow_klass_base()); if (Universe::narrow_klass_base() != 0) {
add(dst, shifted_src, R0); load_const(R0, Universe::narrow_klass_base());
add(dst, shifted_src, R0);
}
} }
void MacroAssembler::load_klass(Register dst, Register src) { void MacroAssembler::load_klass(Register dst, Register src) {
......
...@@ -551,6 +551,7 @@ class MacroAssembler: public Assembler { ...@@ -551,6 +551,7 @@ class MacroAssembler: public Assembler {
void load_klass(Register dst, Register src); void load_klass(Register dst, Register src);
void load_klass_with_trap_null_check(Register dst, Register src); void load_klass_with_trap_null_check(Register dst, Register src);
void store_klass(Register dst_oop, Register klass, Register tmp = R0); void store_klass(Register dst_oop, Register klass, Register tmp = R0);
static int instr_size_for_decode_klass_not_null();
void decode_klass_not_null(Register dst, Register src = noreg); void decode_klass_not_null(Register dst, Register src = noreg);
void encode_klass_not_null(Register dst, Register src = noreg); void encode_klass_not_null(Register dst, Register src = noreg);
......
...@@ -255,10 +255,11 @@ int VtableStub::pd_code_size_limit(bool is_vtable_stub) { ...@@ -255,10 +255,11 @@ int VtableStub::pd_code_size_limit(bool is_vtable_stub) {
if (TraceJumps || DebugVtables || CountCompiledCalls || VerifyOops) { if (TraceJumps || DebugVtables || CountCompiledCalls || VerifyOops) {
return 1000; return 1000;
} else { } else {
int decode_klass_size = MacroAssembler::instr_size_for_decode_klass_not_null();
if (is_vtable_stub) { if (is_vtable_stub) {
return 20 + 16 + 8; // Plain + (cOops & Traps) + safety return 20 + decode_klass_size + 8 + 8; // Plain + cOops + Traps + safety
} else { } else {
return 16 + 96; return 96 + decode_klass_size + 12 + 8; // Plain + cOops + Traps + safety
} }
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册