Commit f15652b4 authored by jgruber's avatar jgruber Committed by Commit Bot

[builtins,arm64] Isolate-independent calls to external references

This changes Call(ExternalReference) to use the correct Mov() overload,
which contains logic to load external references indirectly (i.e. in an
isolate-independent way).

Bug: v8:6666, v8:7985
Change-Id: Ib6f3931308c7d13fd4ef0563b7e1e83db3a760eb
Reviewed-on: https://chromium-review.googlesource.com/1152730
Commit-Queue: Jakob Gruber <jgruber@chromium.org>
Reviewed-by: 's avatarClemens Hammacher <clemensh@chromium.org>
Reviewed-by: 's avatarSigurd Schneider <sigurds@chromium.org>
Cr-Commit-Position: refs/heads/master@{#54813}
parent 85cef38d
...@@ -355,6 +355,7 @@ void TurboAssembler::Mov(const Register& rd, ExternalReference reference) { ...@@ -355,6 +355,7 @@ void TurboAssembler::Mov(const Register& rd, ExternalReference reference) {
return; return;
} }
} }
// The Immediate in Operand sets the relocation mode.
Mov(rd, Operand(reference)); Mov(rd, Operand(reference));
} }
...@@ -2027,9 +2028,7 @@ void TurboAssembler::Call(Handle<Code> code, RelocInfo::Mode rmode) { ...@@ -2027,9 +2028,7 @@ void TurboAssembler::Call(Handle<Code> code, RelocInfo::Mode rmode) {
void TurboAssembler::Call(ExternalReference target) { void TurboAssembler::Call(ExternalReference target) {
UseScratchRegisterScope temps(this); UseScratchRegisterScope temps(this);
Register temp = temps.AcquireX(); Register temp = temps.AcquireX();
// Immediate is in charge of setting the relocation mode to Mov(temp, target);
// EXTERNAL_REFERENCE.
Mov(temp, Immediate(target));
Call(temp); Call(temp);
} }
...@@ -3000,13 +2999,6 @@ void TurboAssembler::Abort(AbortReason reason) { ...@@ -3000,13 +2999,6 @@ void TurboAssembler::Abort(AbortReason reason) {
TmpList()->Combine(MacroAssembler::DefaultTmpList()); TmpList()->Combine(MacroAssembler::DefaultTmpList());
if (should_abort_hard()) { if (should_abort_hard()) {
// TODO(7985): Isolate independent builtins cannot tolerate external
// references, so we just provoke a segfault to indicate the error.
if (options().isolate_independent_code) {
Move(x1, 0);
Ldr(x1, MemOperand(x1));
return;
}
// We don't care if we constructed a frame. Just pretend we did. // We don't care if we constructed a frame. Just pretend we did.
FrameScope assume_frame(this, StackFrame::NONE); FrameScope assume_frame(this, StackFrame::NONE);
Mov(w0, static_cast<int>(reason)); Mov(w0, static_cast<int>(reason));
......
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