Commit 5f47fe15 authored by jochen@chromium.org's avatar jochen@chromium.org

Remove support for parallel sweeping

BUG=none
R=hpayer@chromium.org
LOG=y

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

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@24382 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 4f7874e3
...@@ -531,10 +531,6 @@ DEFINE_BOOL(trace_incremental_marking, false, ...@@ -531,10 +531,6 @@ DEFINE_BOOL(trace_incremental_marking, false,
"trace progress of the incremental marking") "trace progress of the incremental marking")
DEFINE_BOOL(track_gc_object_stats, false, DEFINE_BOOL(track_gc_object_stats, false,
"track object counts and memory usage") "track object counts and memory usage")
DEFINE_BOOL(parallel_sweeping, false, "enable parallel sweeping")
DEFINE_BOOL(concurrent_sweeping, true, "enable concurrent sweeping")
DEFINE_INT(sweeper_threads, 0,
"number of parallel and concurrent sweeping threads")
#ifdef VERIFY_HEAP #ifdef VERIFY_HEAP
DEFINE_BOOL(verify_heap, false, "verify heap pointers before and after GC") DEFINE_BOOL(verify_heap, false, "verify heap pointers before and after GC")
#endif #endif
...@@ -663,8 +659,6 @@ DEFINE_BOOL(profile_hydrogen_code_stub_compilation, false, ...@@ -663,8 +659,6 @@ DEFINE_BOOL(profile_hydrogen_code_stub_compilation, false,
DEFINE_BOOL(predictable, false, "enable predictable mode") DEFINE_BOOL(predictable, false, "enable predictable mode")
DEFINE_NEG_IMPLICATION(predictable, concurrent_recompilation) DEFINE_NEG_IMPLICATION(predictable, concurrent_recompilation)
DEFINE_NEG_IMPLICATION(predictable, concurrent_osr) DEFINE_NEG_IMPLICATION(predictable, concurrent_osr)
DEFINE_NEG_IMPLICATION(predictable, concurrent_sweeping)
DEFINE_NEG_IMPLICATION(predictable, parallel_sweeping)
// //
......
...@@ -4167,7 +4167,6 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) { ...@@ -4167,7 +4167,6 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) {
switch (sweeper) { switch (sweeper) {
case CONCURRENT_SWEEPING: case CONCURRENT_SWEEPING:
case PARALLEL_SWEEPING:
if (!parallel_sweeping_active) { if (!parallel_sweeping_active) {
if (FLAG_gc_verbose) { if (FLAG_gc_verbose) {
PrintF("Sweeping 0x%" V8PRIxPTR ".\n", PrintF("Sweeping 0x%" V8PRIxPTR ".\n",
...@@ -4218,19 +4217,6 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) { ...@@ -4218,19 +4217,6 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, SweeperType sweeper) {
} }
static bool ShouldStartSweeperThreads(MarkCompactCollector::SweeperType type) {
return (type == MarkCompactCollector::PARALLEL_SWEEPING ||
type == MarkCompactCollector::CONCURRENT_SWEEPING) &&
!FLAG_predictable;
}
static bool ShouldWaitForSweeperThreads(
MarkCompactCollector::SweeperType type) {
return type == MarkCompactCollector::PARALLEL_SWEEPING;
}
void MarkCompactCollector::SweepSpaces() { void MarkCompactCollector::SweepSpaces() {
GCTracer::Scope gc_scope(heap()->tracer(), GCTracer::Scope::MC_SWEEP); GCTracer::Scope gc_scope(heap()->tracer(), GCTracer::Scope::MC_SWEEP);
double start_time = 0.0; double start_time = 0.0;
...@@ -4241,10 +4227,6 @@ void MarkCompactCollector::SweepSpaces() { ...@@ -4241,10 +4227,6 @@ void MarkCompactCollector::SweepSpaces() {
#ifdef DEBUG #ifdef DEBUG
state_ = SWEEP_SPACES; state_ = SWEEP_SPACES;
#endif #endif
SweeperType how_to_sweep = CONCURRENT_SWEEPING;
if (FLAG_parallel_sweeping) how_to_sweep = PARALLEL_SWEEPING;
if (FLAG_concurrent_sweeping) how_to_sweep = CONCURRENT_SWEEPING;
MoveEvacuationCandidatesToEndOfPagesList(); MoveEvacuationCandidatesToEndOfPagesList();
// Noncompacting collections simply sweep the spaces to clear the mark // Noncompacting collections simply sweep the spaces to clear the mark
...@@ -4257,17 +4239,13 @@ void MarkCompactCollector::SweepSpaces() { ...@@ -4257,17 +4239,13 @@ void MarkCompactCollector::SweepSpaces() {
GCTracer::Scope::MC_SWEEP_OLDSPACE); GCTracer::Scope::MC_SWEEP_OLDSPACE);
{ {
SequentialSweepingScope scope(this); SequentialSweepingScope scope(this);
SweepSpace(heap()->old_pointer_space(), how_to_sweep); SweepSpace(heap()->old_pointer_space(), CONCURRENT_SWEEPING);
SweepSpace(heap()->old_data_space(), how_to_sweep); SweepSpace(heap()->old_data_space(), CONCURRENT_SWEEPING);
} }
if (ShouldStartSweeperThreads(how_to_sweep)) { if (!FLAG_predictable) {
StartSweeperThreads(); StartSweeperThreads();
} }
if (ShouldWaitForSweeperThreads(how_to_sweep)) {
EnsureSweepingCompleted();
}
} }
RemoveDeadInvalidatedCode(); RemoveDeadInvalidatedCode();
......
...@@ -547,7 +547,6 @@ class MarkCompactCollector { ...@@ -547,7 +547,6 @@ class MarkCompactCollector {
void EnableCodeFlushing(bool enable); void EnableCodeFlushing(bool enable);
enum SweeperType { enum SweeperType {
PARALLEL_SWEEPING,
CONCURRENT_SWEEPING, CONCURRENT_SWEEPING,
SEQUENTIAL_SWEEPING SEQUENTIAL_SWEEPING
}; };
......
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