8286297: G1: Simplify parallel and serial verification code paths
Reviewed-by: ayang, lkorinth
This commit is contained in:
parent
0155e4b76b
commit
652044d82b
@ -352,15 +352,13 @@ void G1HeapVerifier::verify_archive_regions() {
|
||||
|
||||
class VerifyRegionClosure: public HeapRegionClosure {
|
||||
private:
|
||||
bool _par;
|
||||
VerifyOption _vo;
|
||||
bool _failures;
|
||||
public:
|
||||
// _vo == UsePrevMarking -> use "prev" marking information,
|
||||
// _vo == UseFullMarking -> use "next" marking bitmap but no TAMS
|
||||
VerifyRegionClosure(bool par, VerifyOption vo)
|
||||
: _par(par),
|
||||
_vo(vo),
|
||||
VerifyRegionClosure(VerifyOption vo)
|
||||
: _vo(vo),
|
||||
_failures(false) {}
|
||||
|
||||
bool failures() {
|
||||
@ -415,9 +413,9 @@ public:
|
||||
}
|
||||
};
|
||||
|
||||
// This is the task used for parallel verification of the heap regions
|
||||
// This is the task used for verification of the heap regions
|
||||
|
||||
class G1ParVerifyTask: public WorkerTask {
|
||||
class G1VerifyTask: public WorkerTask {
|
||||
private:
|
||||
G1CollectedHeap* _g1h;
|
||||
VerifyOption _vo;
|
||||
@ -427,8 +425,8 @@ private:
|
||||
public:
|
||||
// _vo == UsePrevMarking -> use "prev" marking information,
|
||||
// _vo == UseFullMarking -> use "next" marking bitmap but no TAMS
|
||||
G1ParVerifyTask(G1CollectedHeap* g1h, VerifyOption vo) :
|
||||
WorkerTask("Parallel verify task"),
|
||||
G1VerifyTask(G1CollectedHeap* g1h, VerifyOption vo) :
|
||||
WorkerTask("Verify task"),
|
||||
_g1h(g1h),
|
||||
_vo(vo),
|
||||
_failures(false),
|
||||
@ -439,7 +437,7 @@ public:
|
||||
}
|
||||
|
||||
void work(uint worker_id) {
|
||||
VerifyRegionClosure blk(true, _vo);
|
||||
VerifyRegionClosure blk(_vo);
|
||||
_g1h->heap_region_par_iterate_from_worker_offset(&blk, &_hrclaimer, worker_id);
|
||||
if (blk.failures()) {
|
||||
_failures = true;
|
||||
@ -491,22 +489,14 @@ void G1HeapVerifier::verify(VerifyOption vo) {
|
||||
}
|
||||
|
||||
log_debug(gc, verify)("HeapRegions");
|
||||
if (GCParallelVerificationEnabled && ParallelGCThreads > 1) {
|
||||
|
||||
G1ParVerifyTask task(_g1h, vo);
|
||||
_g1h->workers()->run_task(&task);
|
||||
uint num_workers = GCParallelVerificationEnabled ? _g1h->workers()->active_workers() : 1u;
|
||||
G1VerifyTask task(_g1h, vo);
|
||||
_g1h->workers()->run_task(&task, num_workers);
|
||||
if (task.failures()) {
|
||||
failures = true;
|
||||
}
|
||||
|
||||
} else {
|
||||
VerifyRegionClosure blk(false, vo);
|
||||
_g1h->heap_region_iterate(&blk);
|
||||
if (blk.failures()) {
|
||||
failures = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (failures) {
|
||||
log_error(gc, verify)("Heap after failed verification (kind %d):", vo);
|
||||
// It helps to have the per-region information in the output to
|
||||
|
Loading…
Reference in New Issue
Block a user