| Index: src/x87/builtins-x87.cc
|
| diff --git a/src/x87/builtins-x87.cc b/src/x87/builtins-x87.cc
|
| index 55ec55fc6f8683e8c335fa5a587bb612388d4557..3e1e2569693ac4d838cec24e6ed28058ad41ddd8 100644
|
| --- a/src/x87/builtins-x87.cc
|
| +++ b/src/x87/builtins-x87.cc
|
| @@ -118,7 +118,8 @@ void Builtins::Generate_InOptimizationQueue(MacroAssembler* masm) {
|
|
|
| static void Generate_JSConstructStubHelper(MacroAssembler* masm,
|
| bool is_api_function,
|
| - bool create_implicit_receiver) {
|
| + bool create_implicit_receiver,
|
| + bool check_derived_construct) {
|
| // ----------- S t a t e -------------
|
| // -- eax: number of arguments
|
| // -- edi: constructor function
|
| @@ -359,6 +360,19 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm,
|
| // Leave construct frame.
|
| }
|
|
|
| + // ES6 9.2.2. Step 13+
|
| + // Check that the result is not a Smi, indicating that the constructor result
|
| + // from a derived class is neither undefined nor an Object.
|
| + if (check_derived_construct) {
|
| + Label dont_throw;
|
| + __ JumpIfNotSmi(eax, &dont_throw);
|
| + {
|
| + FrameScope scope(masm, StackFrame::INTERNAL);
|
| + __ CallRuntime(Runtime::kThrowDerivedConstructorReturnedNonObject);
|
| + }
|
| + __ bind(&dont_throw);
|
| + }
|
| +
|
| // Remove caller arguments from the stack and return.
|
| STATIC_ASSERT(kSmiTagSize == 1 && kSmiTag == 0);
|
| __ pop(ecx);
|
| @@ -372,17 +386,23 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm,
|
|
|
|
|
| void Builtins::Generate_JSConstructStubGeneric(MacroAssembler* masm) {
|
| - Generate_JSConstructStubHelper(masm, false, true);
|
| + Generate_JSConstructStubHelper(masm, false, true, false);
|
| }
|
|
|
|
|
| void Builtins::Generate_JSConstructStubApi(MacroAssembler* masm) {
|
| - Generate_JSConstructStubHelper(masm, true, true);
|
| + Generate_JSConstructStubHelper(masm, true, true, false);
|
| }
|
|
|
|
|
| void Builtins::Generate_JSBuiltinsConstructStub(MacroAssembler* masm) {
|
| - Generate_JSConstructStubHelper(masm, false, false);
|
| + Generate_JSConstructStubHelper(masm, false, false, false);
|
| +}
|
| +
|
| +
|
| +void Builtins::Generate_JSBuiltinsConstructStubForDerived(
|
| + MacroAssembler* masm) {
|
| + Generate_JSConstructStubHelper(masm, false, false, true);
|
| }
|
|
|
|
|
|
|