[ia32,root] Preserve kRootRegister (ebx) in two more builtins
This CL ensures that ConstructBoundFunction and ConstructedNonConstructable preserve the kRootRegister (ebx). Bug: v8:6666 Change-Id: I5aaee07aee9377f62028c98ccc8c6fdfe23dbc6d Reviewed-on: https://chromium-review.googlesource.com/1233615 Commit-Queue: Sigurd Schneider <sigurds@chromium.org> Reviewed-by: Jakob Gruber <jgruber@chromium.org> Cr-Commit-Position: refs/heads/master@{#56033}
This commit is contained in:
parent
4491072507
commit
4862381365
@ -315,6 +315,7 @@ void Builtins::Generate_JSBuiltinsConstructStub(MacroAssembler* masm) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Builtins::Generate_ConstructedNonConstructable(MacroAssembler* masm) {
|
void Builtins::Generate_ConstructedNonConstructable(MacroAssembler* masm) {
|
||||||
|
Assembler::SupportsRootRegisterScope supports_root_register(masm);
|
||||||
FrameScope scope(masm, StackFrame::INTERNAL);
|
FrameScope scope(masm, StackFrame::INTERNAL);
|
||||||
__ push(edi);
|
__ push(edi);
|
||||||
__ CallRuntime(Runtime::kThrowConstructedNonConstructable);
|
__ CallRuntime(Runtime::kThrowConstructedNonConstructable);
|
||||||
@ -1969,32 +1970,35 @@ void Builtins::Generate_CallFunction(MacroAssembler* masm,
|
|||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
void Generate_PushBoundArguments(MacroAssembler* masm) {
|
void Generate_PushBoundArguments(MacroAssembler* masm) {
|
||||||
|
Assembler::SupportsRootRegisterScope supports_root_register(masm);
|
||||||
// ----------- S t a t e -------------
|
// ----------- S t a t e -------------
|
||||||
// -- eax : the number of arguments (not including the receiver)
|
// -- eax : the number of arguments (not including the receiver)
|
||||||
// -- edx : new.target (only in case of [[Construct]])
|
// -- edx : new.target (only in case of [[Construct]])
|
||||||
// -- edi : target (checked to be a JSBoundFunction)
|
// -- edi : target (checked to be a JSBoundFunction)
|
||||||
// -----------------------------------
|
// -----------------------------------
|
||||||
|
|
||||||
// Load [[BoundArguments]] into ecx and length of that into ebx.
|
__ movd(xmm0, edx); // Spill edx.
|
||||||
|
|
||||||
|
// Load [[BoundArguments]] into ecx and length of that into edx.
|
||||||
Label no_bound_arguments;
|
Label no_bound_arguments;
|
||||||
__ mov(ecx, FieldOperand(edi, JSBoundFunction::kBoundArgumentsOffset));
|
__ mov(ecx, FieldOperand(edi, JSBoundFunction::kBoundArgumentsOffset));
|
||||||
__ mov(ebx, FieldOperand(ecx, FixedArray::kLengthOffset));
|
__ mov(edx, FieldOperand(ecx, FixedArray::kLengthOffset));
|
||||||
__ SmiUntag(ebx);
|
__ SmiUntag(edx);
|
||||||
__ test(ebx, ebx);
|
__ test(edx, edx);
|
||||||
__ j(zero, &no_bound_arguments);
|
__ j(zero, &no_bound_arguments);
|
||||||
{
|
{
|
||||||
// ----------- S t a t e -------------
|
// ----------- S t a t e -------------
|
||||||
// -- eax : the number of arguments (not including the receiver)
|
// -- eax : the number of arguments (not including the receiver)
|
||||||
// -- edx : new.target (only in case of [[Construct]])
|
// -- xmm0 : new.target (only in case of [[Construct]])
|
||||||
// -- edi : target (checked to be a JSBoundFunction)
|
// -- edi : target (checked to be a JSBoundFunction)
|
||||||
// -- ecx : the [[BoundArguments]] (implemented as FixedArray)
|
// -- ecx : the [[BoundArguments]] (implemented as FixedArray)
|
||||||
// -- ebx : the number of [[BoundArguments]]
|
// -- edx : the number of [[BoundArguments]]
|
||||||
// -----------------------------------
|
// -----------------------------------
|
||||||
|
|
||||||
// Reserve stack space for the [[BoundArguments]].
|
// Reserve stack space for the [[BoundArguments]].
|
||||||
{
|
{
|
||||||
Label done;
|
Label done;
|
||||||
__ lea(ecx, Operand(ebx, times_pointer_size, 0));
|
__ lea(ecx, Operand(edx, times_pointer_size, 0));
|
||||||
__ sub(esp, ecx);
|
__ sub(esp, ecx);
|
||||||
// Check the stack for overflow. We are not trying to catch interruptions
|
// Check the stack for overflow. We are not trying to catch interruptions
|
||||||
// (i.e. debug break and preemption) here, so check the "real stack
|
// (i.e. debug break and preemption) here, so check the "real stack
|
||||||
@ -2002,7 +2006,7 @@ void Generate_PushBoundArguments(MacroAssembler* masm) {
|
|||||||
__ CompareRoot(esp, ecx, Heap::kRealStackLimitRootIndex);
|
__ CompareRoot(esp, ecx, Heap::kRealStackLimitRootIndex);
|
||||||
__ j(above_equal, &done, Label::kNear);
|
__ j(above_equal, &done, Label::kNear);
|
||||||
// Restore the stack pointer.
|
// Restore the stack pointer.
|
||||||
__ lea(esp, Operand(esp, ebx, times_pointer_size, 0));
|
__ lea(esp, Operand(esp, edx, times_pointer_size, 0));
|
||||||
{
|
{
|
||||||
FrameScope scope(masm, StackFrame::MANUAL);
|
FrameScope scope(masm, StackFrame::MANUAL);
|
||||||
__ EnterFrame(StackFrame::INTERNAL);
|
__ EnterFrame(StackFrame::INTERNAL);
|
||||||
@ -2018,10 +2022,10 @@ void Generate_PushBoundArguments(MacroAssembler* masm) {
|
|||||||
{
|
{
|
||||||
Label loop;
|
Label loop;
|
||||||
__ Set(ecx, 0);
|
__ Set(ecx, 0);
|
||||||
__ lea(ebx, Operand(esp, ebx, times_pointer_size, 0));
|
__ lea(edx, Operand(esp, edx, times_pointer_size, 0));
|
||||||
__ bind(&loop);
|
__ bind(&loop);
|
||||||
__ movd(xmm0, Operand(ebx, ecx, times_pointer_size, 0));
|
__ movd(xmm1, Operand(edx, ecx, times_pointer_size, 0));
|
||||||
__ movd(Operand(esp, ecx, times_pointer_size, 0), xmm0);
|
__ movd(Operand(esp, ecx, times_pointer_size, 0), xmm1);
|
||||||
__ inc(ecx);
|
__ inc(ecx);
|
||||||
__ cmp(ecx, eax);
|
__ cmp(ecx, eax);
|
||||||
__ j(less, &loop);
|
__ j(less, &loop);
|
||||||
@ -2031,13 +2035,13 @@ void Generate_PushBoundArguments(MacroAssembler* masm) {
|
|||||||
{
|
{
|
||||||
Label loop;
|
Label loop;
|
||||||
__ mov(ecx, FieldOperand(edi, JSBoundFunction::kBoundArgumentsOffset));
|
__ mov(ecx, FieldOperand(edi, JSBoundFunction::kBoundArgumentsOffset));
|
||||||
__ mov(ebx, FieldOperand(ecx, FixedArray::kLengthOffset));
|
__ mov(edx, FieldOperand(ecx, FixedArray::kLengthOffset));
|
||||||
__ SmiUntag(ebx);
|
__ SmiUntag(edx);
|
||||||
__ bind(&loop);
|
__ bind(&loop);
|
||||||
__ dec(ebx);
|
__ dec(edx);
|
||||||
__ movd(xmm0, FieldOperand(ecx, ebx, times_pointer_size,
|
__ movd(xmm1, FieldOperand(ecx, edx, times_pointer_size,
|
||||||
FixedArray::kHeaderSize));
|
FixedArray::kHeaderSize));
|
||||||
__ movd(Operand(esp, eax, times_pointer_size, 0), xmm0);
|
__ movd(Operand(esp, eax, times_pointer_size, 0), xmm1);
|
||||||
__ lea(eax, Operand(eax, 1));
|
__ lea(eax, Operand(eax, 1));
|
||||||
__ j(greater, &loop);
|
__ j(greater, &loop);
|
||||||
}
|
}
|
||||||
@ -2047,7 +2051,9 @@ void Generate_PushBoundArguments(MacroAssembler* masm) {
|
|||||||
// [[BoundArguments]]), so we need to subtract one for the return address.
|
// [[BoundArguments]]), so we need to subtract one for the return address.
|
||||||
__ dec(eax);
|
__ dec(eax);
|
||||||
}
|
}
|
||||||
|
|
||||||
__ bind(&no_bound_arguments);
|
__ bind(&no_bound_arguments);
|
||||||
|
__ movd(edx, xmm0); // Reload edx.
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
@ -2154,6 +2160,7 @@ void Builtins::Generate_ConstructFunction(MacroAssembler* masm) {
|
|||||||
|
|
||||||
// static
|
// static
|
||||||
void Builtins::Generate_ConstructBoundFunction(MacroAssembler* masm) {
|
void Builtins::Generate_ConstructBoundFunction(MacroAssembler* masm) {
|
||||||
|
Assembler::SupportsRootRegisterScope supports_root_register(masm);
|
||||||
// ----------- S t a t e -------------
|
// ----------- S t a t e -------------
|
||||||
// -- eax : the number of arguments (not including the receiver)
|
// -- eax : the number of arguments (not including the receiver)
|
||||||
// -- edx : the new target (checked to be a constructor)
|
// -- edx : the new target (checked to be a constructor)
|
||||||
|
Loading…
Reference in New Issue
Block a user