8256813: Simplify WeakProcessor counting of OopStorage entries
Reviewed-by: sjohanss, stefank
This commit is contained in:
parent
67a959002d
commit
cc96b0acbc
@ -65,9 +65,9 @@ void WeakProcessor::weak_oops_do(BoolObjectClosure* is_alive, OopClosure* keep_a
|
|||||||
OopStorageSet::Iterator it = OopStorageSet::weak_iterator();
|
OopStorageSet::Iterator it = OopStorageSet::weak_iterator();
|
||||||
for ( ; !it.is_end(); ++it) {
|
for ( ; !it.is_end(); ++it) {
|
||||||
if (it->should_report_num_dead()) {
|
if (it->should_report_num_dead()) {
|
||||||
CountingSkippedIsAliveClosure<BoolObjectClosure, OopClosure> cl(is_alive, keep_alive);
|
CountingClosure<BoolObjectClosure, OopClosure> cl(is_alive, keep_alive);
|
||||||
it->oops_do(&cl);
|
it->oops_do(&cl);
|
||||||
it->report_num_dead(cl.num_skipped() + cl.num_dead());
|
it->report_num_dead(cl.dead());
|
||||||
} else {
|
} else {
|
||||||
it->weak_oops_do(is_alive, keep_alive);
|
it->weak_oops_do(is_alive, keep_alive);
|
||||||
}
|
}
|
||||||
@ -91,12 +91,6 @@ uint WeakProcessor::ergo_workers(uint max_workers) {
|
|||||||
|
|
||||||
// One thread per ReferencesPerThread references (or fraction thereof)
|
// One thread per ReferencesPerThread references (or fraction thereof)
|
||||||
// in the various OopStorage objects, bounded by max_threads.
|
// in the various OopStorage objects, bounded by max_threads.
|
||||||
//
|
|
||||||
// Serial phases are ignored in this calculation, because of the
|
|
||||||
// cost of running unnecessary threads. These phases are normally
|
|
||||||
// small or empty (assuming they are configured to exist at all),
|
|
||||||
// and development oriented, so not allocating any threads
|
|
||||||
// specifically for them is okay.
|
|
||||||
size_t ref_count = 0;
|
size_t ref_count = 0;
|
||||||
OopStorageSet::Iterator it = OopStorageSet::weak_iterator();
|
OopStorageSet::Iterator it = OopStorageSet::weak_iterator();
|
||||||
for ( ; !it.is_end(); ++it) {
|
for ( ; !it.is_end(); ++it) {
|
||||||
|
@ -71,6 +71,9 @@ public:
|
|||||||
class Task;
|
class Task;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
template<typename IsAlive, typename KeepAlive>
|
||||||
|
class CountingClosure;
|
||||||
|
|
||||||
class GangTask;
|
class GangTask;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -38,52 +38,39 @@
|
|||||||
class BoolObjectClosure;
|
class BoolObjectClosure;
|
||||||
class OopClosure;
|
class OopClosure;
|
||||||
|
|
||||||
template<typename IsAlive>
|
|
||||||
class CountingIsAliveClosure : public BoolObjectClosure {
|
|
||||||
IsAlive* _inner;
|
|
||||||
|
|
||||||
size_t _num_dead;
|
|
||||||
size_t _num_total;
|
|
||||||
|
|
||||||
public:
|
|
||||||
CountingIsAliveClosure(IsAlive* cl) : _inner(cl), _num_dead(0), _num_total(0) { }
|
|
||||||
|
|
||||||
virtual bool do_object_b(oop obj) {
|
|
||||||
bool result = _inner->do_object_b(obj);
|
|
||||||
_num_dead += !result;
|
|
||||||
_num_total++;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t num_dead() const { return _num_dead; }
|
|
||||||
size_t num_total() const { return _num_total; }
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename IsAlive, typename KeepAlive>
|
template <typename IsAlive, typename KeepAlive>
|
||||||
class CountingSkippedIsAliveClosure : public Closure {
|
class WeakProcessor::CountingClosure : public Closure {
|
||||||
CountingIsAliveClosure<IsAlive> _counting_is_alive;
|
IsAlive* _is_alive;
|
||||||
KeepAlive* _keep_alive;
|
KeepAlive* _keep_alive;
|
||||||
|
size_t _old_dead;
|
||||||
size_t _num_skipped;
|
size_t _new_dead;
|
||||||
|
size_t _live;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CountingSkippedIsAliveClosure(IsAlive* is_alive, KeepAlive* keep_alive) :
|
CountingClosure(IsAlive* is_alive, KeepAlive* keep_alive) :
|
||||||
_counting_is_alive(is_alive), _keep_alive(keep_alive), _num_skipped(0) { }
|
_is_alive(is_alive),
|
||||||
|
_keep_alive(keep_alive),
|
||||||
|
_old_dead(0),
|
||||||
|
_new_dead(0),
|
||||||
|
_live(0)
|
||||||
|
{}
|
||||||
|
|
||||||
void do_oop(oop* p) {
|
void do_oop(oop* p) {
|
||||||
oop obj = *p;
|
oop obj = *p;
|
||||||
if (obj == NULL) {
|
if (obj == NULL) {
|
||||||
_num_skipped++;
|
++_old_dead;
|
||||||
} else if (_counting_is_alive.do_object_b(obj)) {
|
} else if (_is_alive->do_object_b(obj)) {
|
||||||
_keep_alive->do_oop(p);
|
_keep_alive->do_oop(p);
|
||||||
|
++_live;
|
||||||
} else {
|
} else {
|
||||||
*p = NULL;
|
*p = NULL;
|
||||||
|
++_new_dead;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t num_dead() const { return _counting_is_alive.num_dead(); }
|
size_t dead() const { return _old_dead + _new_dead; }
|
||||||
size_t num_skipped() const { return _num_skipped; }
|
size_t new_dead() const { return _new_dead; }
|
||||||
size_t num_total() const { return _counting_is_alive.num_total() + num_skipped(); }
|
size_t total() const { return dead() + _live; }
|
||||||
};
|
};
|
||||||
|
|
||||||
template<typename IsAlive, typename KeepAlive>
|
template<typename IsAlive, typename KeepAlive>
|
||||||
@ -98,13 +85,13 @@ void WeakProcessor::Task::work(uint worker_id,
|
|||||||
|
|
||||||
for (Iterator it = WeakProcessorPhases::oopstorage_iterator(); !it.is_end(); ++it) {
|
for (Iterator it = WeakProcessorPhases::oopstorage_iterator(); !it.is_end(); ++it) {
|
||||||
WeakProcessorPhase phase = *it;
|
WeakProcessorPhase phase = *it;
|
||||||
CountingSkippedIsAliveClosure<IsAlive, KeepAlive> cl(is_alive, keep_alive);
|
CountingClosure<IsAlive, KeepAlive> cl(is_alive, keep_alive);
|
||||||
WeakProcessorPhaseTimeTracker pt(_phase_times, phase, worker_id);
|
WeakProcessorPhaseTimeTracker pt(_phase_times, phase, worker_id);
|
||||||
StorageState* cur_state = _storage_states.par_state(phase);
|
StorageState* cur_state = _storage_states.par_state(phase);
|
||||||
cur_state->oops_do(&cl);
|
cur_state->oops_do(&cl);
|
||||||
cur_state->increment_num_dead(cl.num_skipped() + cl.num_dead());
|
cur_state->increment_num_dead(cl.dead());
|
||||||
if (_phase_times != NULL) {
|
if (_phase_times != NULL) {
|
||||||
_phase_times->record_worker_items(worker_id, phase, cl.num_dead(), cl.num_total());
|
_phase_times->record_worker_items(worker_id, phase, cl.new_dead(), cl.total());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user