Index: src/debug.cc |
diff --git a/src/debug.cc b/src/debug.cc |
index 35ce3e7ec89779bedf077789d21c1c2c936e7485..b13a1631573b2aa3db7bb26e4a302bcc9317ce72 100644 |
--- a/src/debug.cc |
+++ b/src/debug.cc |
@@ -2041,7 +2041,6 @@ void Debug::PrepareForBreakPoints() { |
Heap* heap = isolate_->heap(); |
heap->CollectAllGarbage(Heap::kMakeHeapIterableMask, |
"preparing for breakpoints"); |
- HeapIterator iterator(heap); |
// Ensure no GC in this scope as we are going to use gc_metadata |
// field in the Code object to mark active functions. |
@@ -2061,6 +2060,7 @@ void Debug::PrepareForBreakPoints() { |
// Scan the heap for all non-optimized functions which have no |
// debug break slots and are not active or inlined into an active |
// function and mark them for lazy compilation. |
+ HeapIterator iterator(heap); |
HeapObject* obj = NULL; |
while (((obj = iterator.next()) != NULL)) { |
if (obj->IsJSFunction()) { |
@@ -2185,7 +2185,9 @@ Object* Debug::FindSharedFunctionInfoInScript(Handle<Script> script, |
Handle<SharedFunctionInfo> target; |
Heap* heap = isolate_->heap(); |
while (!done) { |
- { // Extra scope for iterator. |
+ { // Extra scope for iterator and no-allocation. |
+ heap->EnsureHeapIsIterable(); |
+ DisallowHeapAllocation no_alloc_during_heap_iteration; |
HeapIterator iterator(heap); |
for (HeapObject* obj = iterator.next(); |
obj != NULL; obj = iterator.next()) { |
@@ -2515,6 +2517,8 @@ void Debug::CreateScriptCache() { |
// scripts which are no longer referenced. The second also sweeps precisely, |
// which saves us doing yet another GC to make the heap iterable. |
heap->CollectAllGarbage(Heap::kNoGCFlags, "Debug::CreateScriptCache"); |
+ heap->CollectAllGarbage(Heap::kMakeHeapIterableMask, |
+ "Debug::CreateScriptCache"); |
ASSERT(script_cache_ == NULL); |
script_cache_ = new ScriptCache(isolate_); |
@@ -2522,6 +2526,7 @@ void Debug::CreateScriptCache() { |
// Scan heap for Script objects. |
int count = 0; |
HeapIterator iterator(heap); |
+ DisallowHeapAllocation no_allocation; |
for (HeapObject* obj = iterator.next(); obj != NULL; obj = iterator.next()) { |
if (obj->IsScript() && Script::cast(obj)->HasValidSource()) { |