X87: new classes: implement correct check for uninitialized this in 'super()'
authorcdai2 <chunyang.dai@intel.com>
Thu, 12 Feb 2015 08:10:56 +0000 (16:10 +0800)
committercdai2 <chunyang.dai@intel.com>
Thu, 12 Feb 2015 08:11:40 +0000 (08:11 +0000)
port fdcf3e59ba4af1aa3c5b31a18e615169c97958ab (r26599)

original commit message:

    new classes: implement correct check for uninitialized this in 'super()'

BUG=
R=weiliang.lin@intel.com

Review URL: https://codereview.chromium.org/913383002

Cr-Commit-Position: refs/heads/master@{#26603}

src/x87/full-codegen-x87.cc

index b45f20dcd7b6153b18e41716dc37045bb219a9fd..ff009fd0a38339d7677c68fac4a765afa5df7a8b 100644 (file)
@@ -3133,19 +3133,9 @@ void FullCodeGenerator::EmitSuperConstructorCall(Call* expr) {
   GetVar(eax, new_target_var);
   __ push(eax);
 
-  SuperReference* super_ref = expr->expression()->AsSuperReference();
   EmitLoadSuperConstructor();
   __ push(result_register());
 
-  Variable* this_var = super_ref->this_var()->var();
-  GetVar(eax, this_var);
-  __ cmp(eax, isolate()->factory()->the_hole_value());
-  Label uninitialized_this;
-  __ j(equal, &uninitialized_this);
-  __ push(Immediate(this_var->name()));
-  __ CallRuntime(Runtime::kThrowReferenceError, 1);
-  __ bind(&uninitialized_this);
-
   // Push the arguments ("left-to-right") on the stack.
   ZoneList<Expression*>* args = expr->arguments();
   int arg_count = args->length();
@@ -3181,6 +3171,16 @@ void FullCodeGenerator::EmitSuperConstructorCall(Call* expr) {
 
   RecordJSReturnSite(expr);
 
+  SuperReference* super_ref = expr->expression()->AsSuperReference();
+  Variable* this_var = super_ref->this_var()->var();
+  GetVar(ecx, this_var);
+  __ cmp(ecx, isolate()->factory()->the_hole_value());
+  Label uninitialized_this;
+  __ j(equal, &uninitialized_this);
+  __ push(Immediate(this_var->name()));
+  __ CallRuntime(Runtime::kThrowReferenceError, 1);
+  __ bind(&uninitialized_this);
+
   EmitVariableAssignment(this_var, Token::INIT_CONST);
   context()->Plug(eax);
 }