Commit 90fa326a authored by zhengxing.li's avatar zhengxing.li Committed by Commit bot

X87: [builtins] NonNumberToNumber and StringToNumber now use CallRuntime...

X87: [builtins] NonNumberToNumber and StringToNumber now use CallRuntime instead of TailCallRuntime.

  port b5c69cbf (r37132)

  original commit message:
  With the tail call, pointers to the JS heap could be pushed on a
  js-to-wasm frame. On the js-to-wasm frame, however, this pointer would
  not be updated by the GC.

BUG=

Review-Url: https://codereview.chromium.org/2108543002
Cr-Commit-Position: refs/heads/master@{#37319}
parent 8d2ae278
...@@ -2692,10 +2692,15 @@ void Builtins::Generate_StringToNumber(MacroAssembler* masm) { ...@@ -2692,10 +2692,15 @@ void Builtins::Generate_StringToNumber(MacroAssembler* masm) {
__ Ret(); __ Ret();
__ bind(&runtime); __ bind(&runtime);
__ PopReturnAddressTo(ecx); // Pop return address. {
__ Push(eax); // Push argument. FrameScope frame(masm, StackFrame::INTERNAL);
__ PushReturnAddressFrom(ecx); // Push return address. // Push argument.
__ TailCallRuntime(Runtime::kStringToNumber); __ push(eax);
// We cannot use a tail call here because this builtin can also be called
// from wasm.
__ CallRuntime(Runtime::kStringToNumber);
}
__ Ret();
} }
// static // static
...@@ -2736,11 +2741,15 @@ void Builtins::Generate_NonNumberToNumber(MacroAssembler* masm) { ...@@ -2736,11 +2741,15 @@ void Builtins::Generate_NonNumberToNumber(MacroAssembler* masm) {
__ mov(eax, FieldOperand(eax, Oddball::kToNumberOffset)); __ mov(eax, FieldOperand(eax, Oddball::kToNumberOffset));
__ Ret(); __ Ret();
__ bind(&not_oddball); __ bind(&not_oddball);
{
__ pop(ecx); // Pop return address. FrameScope frame(masm, StackFrame::INTERNAL);
__ push(eax); // Push argument. // Push argument.
__ push(ecx); // Push return address. __ push(eax);
__ TailCallRuntime(Runtime::kToNumber); // We cannot use a tail call here because this builtin can also be called
// from wasm.
__ CallRuntime(Runtime::kToNumber);
}
__ Ret();
} }
void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) { void Builtins::Generate_ArgumentsAdaptorTrampoline(MacroAssembler* masm) {
......
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