Commit ea25bf05 authored by mstarzinger's avatar mstarzinger Committed by Commit bot

[heap] Separate scavenger functionality into own file.

This moves scavenging functionality into a separate component so that
neither the scavenger nor objects-visiting need to be exposed outside
the heap.

R=hpayer@chromium.org,mlippautz@chromium.org

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

Cr-Commit-Position: refs/heads/master@{#30712}
parent 5ee2ea3c
...@@ -984,6 +984,9 @@ source_set("v8_base") { ...@@ -984,6 +984,9 @@ source_set("v8_base") {
"src/heap/objects-visiting-inl.h", "src/heap/objects-visiting-inl.h",
"src/heap/objects-visiting.cc", "src/heap/objects-visiting.cc",
"src/heap/objects-visiting.h", "src/heap/objects-visiting.h",
"src/heap/scavenger-inl.h",
"src/heap/scavenger.cc",
"src/heap/scavenger.h",
"src/heap/spaces-inl.h", "src/heap/spaces-inl.h",
"src/heap/spaces.cc", "src/heap/spaces.cc",
"src/heap/spaces.h", "src/heap/spaces.h",
......
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include "src/counters.h" #include "src/counters.h"
#include "src/heap/heap.h" #include "src/heap/heap.h"
#include "src/heap/incremental-marking-inl.h" #include "src/heap/incremental-marking-inl.h"
#include "src/heap/objects-visiting.h"
#include "src/heap/spaces-inl.h" #include "src/heap/spaces-inl.h"
#include "src/heap/store-buffer.h" #include "src/heap/store-buffer.h"
#include "src/heap/store-buffer-inl.h" #include "src/heap/store-buffer-inl.h"
...@@ -460,9 +461,6 @@ void Heap::MoveBlock(Address dst, Address src, int byte_size) { ...@@ -460,9 +461,6 @@ void Heap::MoveBlock(Address dst, Address src, int byte_size) {
} }
void Heap::ScavengePointer(HeapObject** p) { ScavengeObject(p, *p); }
AllocationMemento* Heap::FindAllocationMemento(HeapObject* object) { AllocationMemento* Heap::FindAllocationMemento(HeapObject* object) {
// Check if there is potentially a memento behind the object. If // Check if there is potentially a memento behind the object. If
// the last word of the memento is on another page we return // the last word of the memento is on another page we return
...@@ -520,33 +518,6 @@ void Heap::UpdateAllocationSiteFeedback(HeapObject* object, ...@@ -520,33 +518,6 @@ void Heap::UpdateAllocationSiteFeedback(HeapObject* object,
} }
void Heap::ScavengeObject(HeapObject** p, HeapObject* object) {
DCHECK(object->GetIsolate()->heap()->InFromSpace(object));
// We use the first word (where the map pointer usually is) of a heap
// object to record the forwarding pointer. A forwarding pointer can
// point to an old space, the code space, or the to space of the new
// generation.
MapWord first_word = object->map_word();
// If the first word is a forwarding address, the object has already been
// copied.
if (first_word.IsForwardingAddress()) {
HeapObject* dest = first_word.ToForwardingAddress();
DCHECK(object->GetIsolate()->heap()->InFromSpace(*p));
*p = dest;
return;
}
UpdateAllocationSiteFeedback(object, IGNORE_SCRATCHPAD_SLOT);
// AllocationMementos are unrooted and shouldn't survive a scavenge
DCHECK(object->map() != object->GetHeap()->allocation_memento_map());
// Call the slow part of scavenge object.
return ScavengeObjectSlow(p, object);
}
bool Heap::CollectGarbage(AllocationSpace space, const char* gc_reason, bool Heap::CollectGarbage(AllocationSpace space, const char* gc_reason,
const v8::GCCallbackFlags callbackFlags) { const v8::GCCallbackFlags callbackFlags) {
const char* collector_reason = NULL; const char* collector_reason = NULL;
......
This diff is collapsed.
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "src/heap/gc-idle-time-handler.h" #include "src/heap/gc-idle-time-handler.h"
#include "src/heap/incremental-marking.h" #include "src/heap/incremental-marking.h"
#include "src/heap/mark-compact.h" #include "src/heap/mark-compact.h"
#include "src/heap/objects-visiting.h"
#include "src/heap/spaces.h" #include "src/heap/spaces.h"
#include "src/heap/store-buffer.h" #include "src/heap/store-buffer.h"
#include "src/list.h" #include "src/list.h"
...@@ -427,6 +426,7 @@ class HeapStats; ...@@ -427,6 +426,7 @@ class HeapStats;
class Isolate; class Isolate;
class MemoryReducer; class MemoryReducer;
class ObjectStats; class ObjectStats;
class Scavenger;
class WeakObjectRetainer; class WeakObjectRetainer;
...@@ -535,10 +535,6 @@ class PromotionQueue { ...@@ -535,10 +535,6 @@ class PromotionQueue {
}; };
typedef void (*ScavengingCallback)(Map* map, HeapObject** slot,
HeapObject* object);
enum ArrayStorageAllocationMode { enum ArrayStorageAllocationMode {
DONT_INITIALIZE_ARRAY_ELEMENTS, DONT_INITIALIZE_ARRAY_ELEMENTS,
INITIALIZE_ARRAY_ELEMENTS_WITH_HOLE INITIALIZE_ARRAY_ELEMENTS_WITH_HOLE
...@@ -719,16 +715,6 @@ class Heap { ...@@ -719,16 +715,6 @@ class Heap {
template <typename T> template <typename T>
static inline bool IsOneByte(T t, int chars); static inline bool IsOneByte(T t, int chars);
// Callback function passed to Heap::Iterate etc. Copies an object if
// necessary, the object might be promoted to an old space. The caller must
// ensure the precondition that the object is (a) a heap object and (b) in
// the heap's from space.
static inline void ScavengePointer(HeapObject** p);
static inline void ScavengeObject(HeapObject** p, HeapObject* object);
// Slow part of scavenge object.
static void ScavengeObjectSlow(HeapObject** p, HeapObject* object);
static void FatalProcessOutOfMemory(const char* location, static void FatalProcessOutOfMemory(const char* location,
bool take_snapshot = false); bool take_snapshot = false);
...@@ -1776,8 +1762,6 @@ class Heap { ...@@ -1776,8 +1762,6 @@ class Heap {
void ConfigureInitialOldGenerationSize(); void ConfigureInitialOldGenerationSize();
void SelectScavengingVisitorsTable();
bool HasLowYoungGenerationAllocationRate(); bool HasLowYoungGenerationAllocationRate();
bool HasLowOldGenerationAllocationRate(); bool HasLowOldGenerationAllocationRate();
double YoungGenerationMutatorUtilization(); double YoungGenerationMutatorUtilization();
...@@ -2259,6 +2243,8 @@ class Heap { ...@@ -2259,6 +2243,8 @@ class Heap {
// Last time a garbage collection happened. // Last time a garbage collection happened.
double last_gc_time_; double last_gc_time_;
Scavenger* scavenge_collector_;
MarkCompactCollector mark_compact_collector_; MarkCompactCollector mark_compact_collector_;
StoreBuffer store_buffer_; StoreBuffer store_buffer_;
...@@ -2318,8 +2304,6 @@ class Heap { ...@@ -2318,8 +2304,6 @@ class Heap {
ExternalStringTable external_string_table_; ExternalStringTable external_string_table_;
VisitorDispatchTable<ScavengingCallback> scavenging_visitors_table_;
MemoryChunk* chunks_queued_for_free_; MemoryChunk* chunks_queued_for_free_;
size_t concurrent_unmapping_tasks_active_; size_t concurrent_unmapping_tasks_active_;
...@@ -2348,6 +2332,7 @@ class Heap { ...@@ -2348,6 +2332,7 @@ class Heap {
friend class MarkCompactMarkingVisitor; friend class MarkCompactMarkingVisitor;
friend class ObjectStatsVisitor; friend class ObjectStatsVisitor;
friend class Page; friend class Page;
friend class Scavenger;
friend class StoreBuffer; friend class StoreBuffer;
// The allocator interface. // The allocator interface.
......
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
#define V8_HEAP_OBJECT_STATS_H_ #define V8_HEAP_OBJECT_STATS_H_
#include "src/heap/heap.h" #include "src/heap/heap.h"
#include "src/heap/objects-visiting.h"
#include "src/objects.h" #include "src/objects.h"
namespace v8 { namespace v8 {
......
// Copyright 2015 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef V8_HEAP_SCAVENGER_INL_H_
#define V8_HEAP_SCAVENGER_INL_H_
#include "src/heap/scavenger.h"
namespace v8 {
namespace internal {
void Scavenger::ScavengeObject(HeapObject** p, HeapObject* object) {
DCHECK(object->GetIsolate()->heap()->InFromSpace(object));
// We use the first word (where the map pointer usually is) of a heap
// object to record the forwarding pointer. A forwarding pointer can
// point to an old space, the code space, or the to space of the new
// generation.
MapWord first_word = object->map_word();
// If the first word is a forwarding address, the object has already been
// copied.
if (first_word.IsForwardingAddress()) {
HeapObject* dest = first_word.ToForwardingAddress();
DCHECK(object->GetIsolate()->heap()->InFromSpace(*p));
*p = dest;
return;
}
Heap::UpdateAllocationSiteFeedback(object, Heap::IGNORE_SCRATCHPAD_SLOT);
// AllocationMementos are unrooted and shouldn't survive a scavenge
DCHECK(object->map() != object->GetHeap()->allocation_memento_map());
// Call the slow part of scavenge object.
return ScavengeObjectSlow(p, object);
}
// static
void StaticScavengeVisitor::VisitPointer(Heap* heap, Object** p) {
Object* object = *p;
if (!heap->InNewSpace(object)) return;
Scavenger::ScavengeObject(reinterpret_cast<HeapObject**>(p),
reinterpret_cast<HeapObject*>(object));
}
} // namespace internal
} // namespace v8
#endif // V8_HEAP_SCAVENGER_INL_H_
This diff is collapsed.
// Copyright 2015 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef V8_HEAP_SCAVENGER_H_
#define V8_HEAP_SCAVENGER_H_
#include "src/heap/objects-visiting.h"
namespace v8 {
namespace internal {
typedef void (*ScavengingCallback)(Map* map, HeapObject** slot,
HeapObject* object);
class Scavenger {
public:
explicit Scavenger(Heap* heap) : heap_(heap) {}
// Initializes static visitor dispatch tables.
static void Initialize();
// Callback function passed to Heap::Iterate etc. Copies an object if
// necessary, the object might be promoted to an old space. The caller must
// ensure the precondition that the object is (a) a heap object and (b) in
// the heap's from space.
static inline void ScavengeObject(HeapObject** p, HeapObject* object);
// Slow part of {ScavengeObject} above.
static void ScavengeObjectSlow(HeapObject** p, HeapObject* object);
// Chooses an appropriate static visitor table depending on the current state
// of the heap (i.e. incremental marking, logging and profiling).
void SelectScavengingVisitorsTable();
Isolate* isolate();
Heap* heap() { return heap_; }
private:
Heap* heap_;
VisitorDispatchTable<ScavengingCallback> scavenging_visitors_table_;
};
// Helper class for turning the scavenger into an object visitor that is also
// filtering out non-HeapObjects and objects which do not reside in new space.
class ScavengeVisitor : public ObjectVisitor {
public:
explicit ScavengeVisitor(Heap* heap) : heap_(heap) {}
void VisitPointer(Object** p);
void VisitPointers(Object** start, Object** end);
private:
inline void ScavengePointer(Object** p);
Heap* heap_;
};
// Helper class for turning the scavenger into an object visitor that is also
// filtering out non-HeapObjects and objects which do not reside in new space.
class StaticScavengeVisitor
: public StaticNewSpaceVisitor<StaticScavengeVisitor> {
public:
static inline void VisitPointer(Heap* heap, Object** p);
};
} // namespace internal
} // namespace v8
#endif // V8_HEAP_SCAVENGER_H_
...@@ -734,6 +734,9 @@ ...@@ -734,6 +734,9 @@
'../../src/heap/objects-visiting-inl.h', '../../src/heap/objects-visiting-inl.h',
'../../src/heap/objects-visiting.cc', '../../src/heap/objects-visiting.cc',
'../../src/heap/objects-visiting.h', '../../src/heap/objects-visiting.h',
'../../src/heap/scavenger-inl.h',
'../../src/heap/scavenger.cc',
'../../src/heap/scavenger.h',
'../../src/heap/spaces-inl.h', '../../src/heap/spaces-inl.h',
'../../src/heap/spaces.cc', '../../src/heap/spaces.cc',
'../../src/heap/spaces.h', '../../src/heap/spaces.h',
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment