Reviewers: Benedikt Meurer, Toon Verwaest,

Description:
Add missing map check to optimized f.apply(...)

This is a cutdown version of https://codereview.chromium.org/346473002/, which aimed to fix f.call and f.apply. Optimized f.call was removed by r21887, this is
what was left.

BUG=386034
LOG=N

Please review this at https://codereview.chromium.org/348623002/

SVN Base: https://v8.googlecode.com/svn/branches/bleeding_edge

Affected files (+13, -8 lines):
  M src/hydrogen.cc
  A + test/mjsunit/regress/regress-386034.js


Index: src/hydrogen.cc
diff --git a/src/hydrogen.cc b/src/hydrogen.cc
index 8be2c6717e2e53107a498adf5a263a11a4275377..6e5ea741bdd0524973f41d487a780d4b0c5c68a8 100644
--- a/src/hydrogen.cc
+++ b/src/hydrogen.cc
@@ -8563,10 +8563,12 @@ bool HOptimizedGraphBuilder::TryCallApply(Call* expr) {
   HValue* function = Pop();  // f
   Drop(1);  // apply

+  HValue* checked_function = AddCheckMap(function, function_map);
+
   if (function_state()->outer() == NULL) {
     HInstruction* elements = Add<HArgumentsElements>(false);
     HInstruction* length = Add<HArgumentsLength>(elements);
-    HValue* wrapped_receiver = BuildWrapReceiver(receiver, function);
+ HValue* wrapped_receiver = BuildWrapReceiver(receiver, checked_function);
     HInstruction* result = New<HApplyArguments>(function,
                                                 wrapped_receiver,
                                                 length,
@@ -8582,7 +8584,7 @@ bool HOptimizedGraphBuilder::TryCallApply(Call* expr) {
     const ZoneList<HValue*>* arguments_values = args->arguments_values();
     int arguments_count = arguments_values->length();
     Push(function);
-    Push(BuildWrapReceiver(receiver, function));
+    Push(BuildWrapReceiver(receiver, checked_function));
     for (int i = 1; i < arguments_count; i++) {
       Push(arguments_values->at(i));
     }
Index: test/mjsunit/regress/regress-386034.js
diff --git a/test/mjsunit/regress/regress-385054.js b/test/mjsunit/regress/regress-386034.js
similarity index 61%
copy from test/mjsunit/regress/regress-385054.js
copy to test/mjsunit/regress/regress-386034.js
index 115bca0d21989e2a82325aeb66d8c06aa5ab198c..d770ce91bd64ad6e1307b1b699948b2513359efc 100644
--- a/test/mjsunit/regress/regress-385054.js
+++ b/test/mjsunit/regress/regress-386034.js
@@ -5,12 +5,15 @@
 // Flags: --allow-natives-syntax

 function f(x) {
-  var a = [1, 2];
-  a[x];
-  return a[0 - x];
+  var v = x;
+  for (i = 0; i < 1; i++) {
+    v.apply(this, arguments);
+  }
 }

-f(0);
-f(0);
+function g() {}
+
+f(g);
+f(g);
 %OptimizeFunctionOnNextCall(f);
-assertEquals(undefined, f(1));
+assertThrows(function() { f('----'); }, TypeError);


--
--
v8-dev mailing list
[email protected]
http://groups.google.com/group/v8-dev
--- You received this message because you are subscribed to the Google Groups "v8-dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
For more options, visit https://groups.google.com/d/optout.

Reply via email to