Commit 1603f672 authored by Milad Farazmand's avatar Milad Farazmand Committed by Commit Bot

PPC/s390: [wasm] Implement patching of far jump table

Port 0a8ddb13

Original Commit Message:

    If the jump is too large for a near jump, we patch the far jump table
    instead, and patch the (near) jump table to jump to the far jump table
    slot.

R=clemensh@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
BUG=
LOG=N

Change-Id: Ic42dfea83799ba6aae1d6d32607391393353815a
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1802742Reviewed-by: 's avatarMilad Farazmand <miladfar@ca.ibm.com>
Reviewed-by: 's avatarJunliang Yan <jyan@ca.ibm.com>
Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
Commit-Queue: Milad Farazmand <miladfar@ca.ibm.com>
Cr-Commit-Position: refs/heads/master@{#63769}
parent fad60ef2
...@@ -198,15 +198,21 @@ void JumpTableAssembler::EmitLazyCompileJumpSlot(uint32_t func_index, ...@@ -198,15 +198,21 @@ void JumpTableAssembler::EmitLazyCompileJumpSlot(uint32_t func_index,
b(r1); // 2 bytes b(r1); // 2 bytes
} }
void JumpTableAssembler::EmitJumpSlot(Address target) { bool JumpTableAssembler::EmitJumpSlot(Address target) {
mov(r1, Operand(target)); mov(r1, Operand(target));
b(r1); b(r1);
return true;
} }
void JumpTableAssembler::EmitFarJumpSlot(Address target) { void JumpTableAssembler::EmitFarJumpSlot(Address target) {
JumpToInstructionStream(target); JumpToInstructionStream(target);
} }
// static
void JumpTableAssembler::PatchFarJumpSlot(Address slot, Address target) {
UNREACHABLE();
}
void JumpTableAssembler::NopBytes(int bytes) { void JumpTableAssembler::NopBytes(int bytes) {
DCHECK_LE(0, bytes); DCHECK_LE(0, bytes);
DCHECK_EQ(0, bytes % 2); DCHECK_EQ(0, bytes % 2);
...@@ -259,16 +265,22 @@ void JumpTableAssembler::EmitLazyCompileJumpSlot(uint32_t func_index, ...@@ -259,16 +265,22 @@ void JumpTableAssembler::EmitLazyCompileJumpSlot(uint32_t func_index,
for (int i = 0; i < nop_bytes; i += kInstrSize) nop(); for (int i = 0; i < nop_bytes; i += kInstrSize) nop();
} }
void JumpTableAssembler::EmitJumpSlot(Address target) { bool JumpTableAssembler::EmitJumpSlot(Address target) {
mov(r0, Operand(target)); mov(r0, Operand(target));
mtctr(r0); mtctr(r0);
bctr(); bctr();
return true;
} }
void JumpTableAssembler::EmitFarJumpSlot(Address target) { void JumpTableAssembler::EmitFarJumpSlot(Address target) {
JumpToInstructionStream(target); JumpToInstructionStream(target);
} }
// static
void JumpTableAssembler::PatchFarJumpSlot(Address slot, Address target) {
UNREACHABLE();
}
void JumpTableAssembler::NopBytes(int bytes) { void JumpTableAssembler::NopBytes(int bytes) {
DCHECK_LE(0, bytes); DCHECK_LE(0, bytes);
DCHECK_EQ(0, bytes % 4); DCHECK_EQ(0, bytes % 4);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment