提交 ac1033dc 编写于 作者: Z zgu

Merge

...@@ -1093,7 +1093,8 @@ bool CompactibleFreeListSpace::block_is_obj(const HeapWord* p) const { ...@@ -1093,7 +1093,8 @@ bool CompactibleFreeListSpace::block_is_obj(const HeapWord* p) const {
// perm_gen_verify_bit_map where we store the "deadness" information if // perm_gen_verify_bit_map where we store the "deadness" information if
// we did not sweep the perm gen in the most recent previous GC cycle. // we did not sweep the perm gen in the most recent previous GC cycle.
bool CompactibleFreeListSpace::obj_is_alive(const HeapWord* p) const { bool CompactibleFreeListSpace::obj_is_alive(const HeapWord* p) const {
assert (block_is_obj(p), "The address should point to an object"); assert(block_is_obj(p), "The address should point to an object");
assert(SafepointSynchronize::is_at_safepoint(), "Else races are possible");
// If we're sweeping, we use object liveness information from the main bit map // If we're sweeping, we use object liveness information from the main bit map
// for both perm gen and old gen. // for both perm gen and old gen.
...@@ -1102,9 +1103,14 @@ bool CompactibleFreeListSpace::obj_is_alive(const HeapWord* p) const { ...@@ -1102,9 +1103,14 @@ bool CompactibleFreeListSpace::obj_is_alive(const HeapWord* p) const {
// main marking bit map (live_map below) is locked, // main marking bit map (live_map below) is locked,
// OR we're in other phases and perm_gen_verify_bit_map (dead_map below) // OR we're in other phases and perm_gen_verify_bit_map (dead_map below)
// is stable, because it's mutated only in the sweeping phase. // is stable, because it's mutated only in the sweeping phase.
// NOTE: This method is also used by jmap where, if class unloading is
// off, the results can return "false" for legitimate perm objects,
// when we are not in the midst of a sweeping phase, which can result
// in jmap not reporting certain perm gen objects. This will be moot
// if/when the perm gen goes away in the future.
if (_collector->abstract_state() == CMSCollector::Sweeping) { if (_collector->abstract_state() == CMSCollector::Sweeping) {
CMSBitMap* live_map = _collector->markBitMap(); CMSBitMap* live_map = _collector->markBitMap();
return live_map->isMarked((HeapWord*) p); return live_map->par_isMarked((HeapWord*) p);
} else { } else {
// If we're not currently sweeping and we haven't swept the perm gen in // If we're not currently sweeping and we haven't swept the perm gen in
// the previous concurrent cycle then we may have dead but unswept objects // the previous concurrent cycle then we may have dead but unswept objects
...@@ -2266,7 +2272,7 @@ void CompactibleFreeListSpace::split(size_t from, size_t to1) { ...@@ -2266,7 +2272,7 @@ void CompactibleFreeListSpace::split(size_t from, size_t to1) {
} }
void CompactibleFreeListSpace::print() const { void CompactibleFreeListSpace::print() const {
Space::print_on(tty); print_on(tty);
} }
void CompactibleFreeListSpace::prepare_for_verify() { void CompactibleFreeListSpace::prepare_for_verify() {
......
...@@ -838,7 +838,9 @@ void DefNewGeneration::gc_epilogue(bool full) { ...@@ -838,7 +838,9 @@ void DefNewGeneration::gc_epilogue(bool full) {
gch->incremental_collection_failed()) { gch->incremental_collection_failed()) {
seen_incremental_collection_failed = true; seen_incremental_collection_failed = true;
} else if (seen_incremental_collection_failed) { } else if (seen_incremental_collection_failed) {
assert(!gch->incremental_collection_failed(), "Twice in a row"); assert(gch->gc_cause() == GCCause::_scavenge_alot || !gch->incremental_collection_failed(),
"Twice in a row");
seen_incremental_collection_failed = false; seen_incremental_collection_failed = false;
} }
#endif // ASSERT #endif // ASSERT
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册