8203344: Make C1 leal patchable on SPARC
Reviewed-by: neliasso, thartmann
This commit is contained in:
parent
78b7362c97
commit
d6cc86f800
@ -3202,23 +3202,38 @@ void LIR_Assembler::leal(LIR_Opr addr_opr, LIR_Opr dest, LIR_PatchCode patch_cod
|
|||||||
const Register dest_reg = dest->as_pointer_register();
|
const Register dest_reg = dest->as_pointer_register();
|
||||||
const Register base_reg = addr->base()->as_pointer_register();
|
const Register base_reg = addr->base()->as_pointer_register();
|
||||||
|
|
||||||
if (Assembler::is_simm13(addr->disp())) {
|
if (patch_code != lir_patch_none) {
|
||||||
if (addr->index()->is_valid()) {
|
PatchingStub* patch = new PatchingStub(_masm, PatchingStub::access_field_id);
|
||||||
const Register index_reg = addr->index()->as_pointer_register();
|
assert(addr->disp() != 0, "must have");
|
||||||
assert(index_reg != G3_scratch, "invariant");
|
assert(base_reg != G3_scratch, "invariant");
|
||||||
__ add(base_reg, addr->disp(), G3_scratch);
|
__ patchable_set(0, G3_scratch);
|
||||||
__ add(index_reg, G3_scratch, dest_reg);
|
patching_epilog(patch, patch_code, base_reg, info);
|
||||||
} else {
|
assert(dest_reg != G3_scratch, "invariant");
|
||||||
__ add(base_reg, addr->disp(), dest_reg);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
__ set(addr->disp(), G3_scratch);
|
|
||||||
if (addr->index()->is_valid()) {
|
if (addr->index()->is_valid()) {
|
||||||
const Register index_reg = addr->index()->as_pointer_register();
|
const Register index_reg = addr->index()->as_pointer_register();
|
||||||
assert(index_reg != G3_scratch, "invariant");
|
assert(index_reg != G3_scratch, "invariant");
|
||||||
__ add(index_reg, G3_scratch, G3_scratch);
|
__ add(index_reg, G3_scratch, G3_scratch);
|
||||||
}
|
}
|
||||||
__ add(base_reg, G3_scratch, dest_reg);
|
__ add(base_reg, G3_scratch, dest_reg);
|
||||||
|
} else {
|
||||||
|
if (Assembler::is_simm13(addr->disp())) {
|
||||||
|
if (addr->index()->is_valid()) {
|
||||||
|
const Register index_reg = addr->index()->as_pointer_register();
|
||||||
|
assert(index_reg != G3_scratch, "invariant");
|
||||||
|
__ add(base_reg, addr->disp(), G3_scratch);
|
||||||
|
__ add(index_reg, G3_scratch, dest_reg);
|
||||||
|
} else {
|
||||||
|
__ add(base_reg, addr->disp(), dest_reg);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
__ set(addr->disp(), G3_scratch);
|
||||||
|
if (addr->index()->is_valid()) {
|
||||||
|
const Register index_reg = addr->index()->as_pointer_register();
|
||||||
|
assert(index_reg != G3_scratch, "invariant");
|
||||||
|
__ add(index_reg, G3_scratch, G3_scratch);
|
||||||
|
}
|
||||||
|
__ add(base_reg, G3_scratch, dest_reg);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user