Revision: 18639
Author:   [email protected]
Date:     Thu Jan 16 10:00:03 2014 UTC
Log:      Refactor DeoptimizeDependentCodeGroup.

BUG=
[email protected]

Review URL: https://codereview.chromium.org/137783016
http://code.google.com/p/v8/source/detail?r=18639

Modified:
 /branches/bleeding_edge/src/heap.cc
 /branches/bleeding_edge/src/objects.cc
 /branches/bleeding_edge/src/objects.h

=======================================
--- /branches/bleeding_edge/src/heap.cc Wed Jan 15 11:42:19 2014 UTC
+++ /branches/bleeding_edge/src/heap.cc Thu Jan 16 10:00:03 2014 UTC
@@ -1983,14 +1983,22 @@


 void Heap::ResetAllAllocationSitesDependentCode(PretenureFlag flag) {
+  ASSERT(AllowCodeDependencyChange::IsAllowed());
+  DisallowHeapAllocation no_allocation_scope;
   Object* cur = allocation_sites_list();
+  bool marked = false;
   while (cur->IsAllocationSite()) {
     AllocationSite* casted = AllocationSite::cast(cur);
     if (casted->GetPretenureMode() == flag) {
       casted->ResetPretenureDecision();
+ bool got_marked = casted->dependent_code()->MarkCodeForDeoptimization(
+          isolate_,
+          DependentCode::kAllocationSiteTenuringChangedGroup);
+      if (got_marked) marked = true;
     }
     cur = casted->weak_next();
   }
+  if (marked) Deoptimizer::DeoptimizeMarkedCode(isolate_);
 }


=======================================
--- /branches/bleeding_edge/src/objects.cc      Wed Jan 15 11:42:19 2014 UTC
+++ /branches/bleeding_edge/src/objects.cc      Thu Jan 16 10:00:03 2014 UTC
@@ -11755,7 +11755,7 @@
 }


-void DependentCode::DeoptimizeDependentCodeGroup(
+bool DependentCode::MarkCodeForDeoptimization(
     Isolate* isolate,
     DependentCode::DependencyGroup group) {
   ASSERT(AllowCodeDependencyChange::IsAllowed());
@@ -11764,7 +11764,7 @@
   int start = starts.at(group);
   int end = starts.at(group + 1);
   int code_entries = starts.number_of_entries();
-  if (start == end) return;
+  if (start == end) return false;

   // Mark all the code that needs to be deoptimized.
   bool marked = false;
@@ -11790,6 +11790,16 @@
     clear_at(i);
   }
   set_number_of_entries(group, 0);
+  return marked;
+}
+
+
+void DependentCode::DeoptimizeDependentCodeGroup(
+    Isolate* isolate,
+    DependentCode::DependencyGroup group) {
+  ASSERT(AllowCodeDependencyChange::IsAllowed());
+  DisallowHeapAllocation no_allocation_scope;
+  bool marked = MarkCodeForDeoptimization(isolate, group);

   if (marked) Deoptimizer::DeoptimizeMarkedCode(isolate);
 }
@@ -12765,9 +12775,6 @@


 void AllocationSite::ResetPretenureDecision() {
-  dependent_code()->DeoptimizeDependentCodeGroup(
-      GetIsolate(),
-      DependentCode::kAllocationSiteTenuringChangedGroup);
   set_pretenure_decision(kUndecided);
   set_memento_found_count(0);
   set_memento_create_count(0);
=======================================
--- /branches/bleeding_edge/src/objects.h       Mon Jan 13 14:54:33 2014 UTC
+++ /branches/bleeding_edge/src/objects.h       Thu Jan 16 10:00:03 2014 UTC
@@ -5642,6 +5642,9 @@
   void DeoptimizeDependentCodeGroup(Isolate* isolate,
                                     DependentCode::DependencyGroup group);

+  bool MarkCodeForDeoptimization(Isolate* isolate,
+                                 DependentCode::DependencyGroup group);
+
   // The following low-level accessors should only be used by this class
   // and the mark compact collector.
   inline int number_of_entries(DependencyGroup group);

--
--
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/groups/opt_out.

Reply via email to