Pass sweeping mode as template parameter.

R=yangguo@chromium.org

Review URL: http://codereview.chromium.org/8060004

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@9440 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 7810ff70
...@@ -2793,10 +2793,9 @@ enum SkipListRebuildingMode { ...@@ -2793,10 +2793,9 @@ enum SkipListRebuildingMode {
// over it. Map space is swept precisely, because it is not compacted. // over it. Map space is swept precisely, because it is not compacted.
// Slots in live objects pointing into evacuation candidates are updated // Slots in live objects pointing into evacuation candidates are updated
// if requested. // if requested.
template<SkipListRebuildingMode skip_list_mode> template<SweepingMode sweeping_mode, SkipListRebuildingMode skip_list_mode>
static void SweepPrecisely(PagedSpace* space, static void SweepPrecisely(PagedSpace* space,
Page* p, Page* p,
SweepingMode mode,
ObjectVisitor* v) { ObjectVisitor* v) {
ASSERT(!p->IsEvacuationCandidate() && !p->WasSwept()); ASSERT(!p->IsEvacuationCandidate() && !p->WasSwept());
ASSERT_EQ(skip_list_mode == REBUILD_SKIP_LIST, ASSERT_EQ(skip_list_mode == REBUILD_SKIP_LIST,
...@@ -2841,7 +2840,7 @@ static void SweepPrecisely(PagedSpace* space, ...@@ -2841,7 +2840,7 @@ static void SweepPrecisely(PagedSpace* space,
ASSERT(Marking::IsBlack(Marking::MarkBitFrom(live_object))); ASSERT(Marking::IsBlack(Marking::MarkBitFrom(live_object)));
Map* map = live_object->map(); Map* map = live_object->map();
int size = live_object->SizeFromMap(map); int size = live_object->SizeFromMap(map);
if (mode == SWEEP_AND_VISIT_LIVE_OBJECTS) { if (sweeping_mode == SWEEP_AND_VISIT_LIVE_OBJECTS) {
live_object->IterateBody(map->instance_type(), size, v); live_object->IterateBody(map->instance_type(), size, v);
} }
if ((skip_list_mode == REBUILD_SKIP_LIST) && skip_list != NULL) { if ((skip_list_mode == REBUILD_SKIP_LIST) && skip_list != NULL) {
...@@ -3069,16 +3068,12 @@ void MarkCompactCollector::EvacuateNewSpaceAndCandidates() { ...@@ -3069,16 +3068,12 @@ void MarkCompactCollector::EvacuateNewSpaceAndCandidates() {
SweepConservatively(space, p); SweepConservatively(space, p);
break; break;
case OLD_POINTER_SPACE: case OLD_POINTER_SPACE:
SweepPrecisely<IGNORE_SKIP_LIST>(space, SweepPrecisely<SWEEP_AND_VISIT_LIVE_OBJECTS, IGNORE_SKIP_LIST>(
p, space, p, &updating_visitor);
SWEEP_AND_VISIT_LIVE_OBJECTS,
&updating_visitor);
break; break;
case CODE_SPACE: case CODE_SPACE:
SweepPrecisely<REBUILD_SKIP_LIST>(space, SweepPrecisely<SWEEP_AND_VISIT_LIVE_OBJECTS, REBUILD_SKIP_LIST>(
p, space, p, &updating_visitor);
SWEEP_AND_VISIT_LIVE_OBJECTS,
&updating_visitor);
break; break;
default: default:
UNREACHABLE(); UNREACHABLE();
...@@ -3618,9 +3613,9 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space, ...@@ -3618,9 +3613,9 @@ void MarkCompactCollector::SweepSpace(PagedSpace* space,
} }
case PRECISE: { case PRECISE: {
if (space->identity() == CODE_SPACE) { if (space->identity() == CODE_SPACE) {
SweepPrecisely<REBUILD_SKIP_LIST>(space, p, SWEEP_ONLY, NULL); SweepPrecisely<SWEEP_ONLY, REBUILD_SKIP_LIST>(space, p, NULL);
} else { } else {
SweepPrecisely<IGNORE_SKIP_LIST>(space, p, SWEEP_ONLY, NULL); SweepPrecisely<SWEEP_ONLY, IGNORE_SKIP_LIST>(space, p, NULL);
} }
break; break;
} }
......
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