提交 b683c26f 编写于 作者: J jmasa

Merge

...@@ -198,8 +198,6 @@ void VM_CollectForMetadataAllocation::doit() { ...@@ -198,8 +198,6 @@ void VM_CollectForMetadataAllocation::doit() {
CollectedHeap* heap = Universe::heap(); CollectedHeap* heap = Universe::heap();
GCCauseSetter gccs(heap, _gc_cause); GCCauseSetter gccs(heap, _gc_cause);
bool do_cms_concurrent = false;
// Check again if the space is available. Another thread // Check again if the space is available. Another thread
// may have similarly failed a metadata allocation and induced // may have similarly failed a metadata allocation and induced
// a GC that freed space for the allocation. // a GC that freed space for the allocation.
...@@ -208,23 +206,25 @@ void VM_CollectForMetadataAllocation::doit() { ...@@ -208,23 +206,25 @@ void VM_CollectForMetadataAllocation::doit() {
} }
if (_result == NULL) { if (_result == NULL) {
if (!UseConcMarkSweepGC) { if (UseConcMarkSweepGC) {
// Don't clear the soft refs the first time. if (CMSClassUnloadingEnabled) {
heap->collect_as_vm_thread(GCCause::_metadata_GC_threshold);
_result = _loader_data->metaspace_non_null()->allocate(_size, _mdtype);
// Don't do this for now
// This seems too costly to do a second full GC
// Let the metaspace grow instead
// if (_result == NULL) {
// // If allocation fails again, clear soft refs
// heap->collect_as_vm_thread(GCCause::_last_ditch_collection);
// _result = _loader_data->metaspace_non_null()->allocate(_size, _mdtype);
// }
} else {
MetaspaceGC::set_should_concurrent_collect(true); MetaspaceGC::set_should_concurrent_collect(true);
do_cms_concurrent = true; }
// For CMS expand since the collection is going to be concurrent.
_result =
_loader_data->metaspace_non_null()->expand_and_allocate(_size, _mdtype);
} }
if (_result == NULL) { if (_result == NULL) {
// Don't clear the soft refs. This GC is for reclaiming metadata
// and is unrelated to the fullness of the Java heap which should
// be the criteria for clearing SoftReferences.
if (Verbose && PrintGCDetails && UseConcMarkSweepGC) {
gclog_or_tty->print_cr("\nCMS full GC for Metaspace");
}
heap->collect_as_vm_thread(GCCause::_metadata_GC_threshold);
_result = _loader_data->metaspace_non_null()->allocate(_size, _mdtype);
}
if (_result == NULL && !UseConcMarkSweepGC /* CMS already tried */) {
// If still failing, allow the Metaspace to expand. // If still failing, allow the Metaspace to expand.
// See delta_capacity_until_GC() for explanation of the // See delta_capacity_until_GC() for explanation of the
// amount of the expansion. // amount of the expansion.
...@@ -233,20 +233,12 @@ void VM_CollectForMetadataAllocation::doit() { ...@@ -233,20 +233,12 @@ void VM_CollectForMetadataAllocation::doit() {
_result = _result =
_loader_data->metaspace_non_null()->expand_and_allocate(_size, _mdtype); _loader_data->metaspace_non_null()->expand_and_allocate(_size, _mdtype);
if (do_cms_concurrent && _result == NULL) {
// Rather than fail with a metaspace out-of-memory, do a full
// GC for CMS.
heap->collect_as_vm_thread(GCCause::_metadata_GC_threshold);
_result = _loader_data->metaspace_non_null()->allocate(_size, _mdtype);
} }
if (_result == NULL) { if (Verbose && PrintGCDetails && _result == NULL) {
if (PrintGCDetails) {
gclog_or_tty->print_cr("\nAfter Metaspace GC failed to allocate size " gclog_or_tty->print_cr("\nAfter Metaspace GC failed to allocate size "
SIZE_FORMAT, _size); SIZE_FORMAT, _size);
} }
} }
}
}
if (_result == NULL && GC_locker::is_active_and_needs_gc()) { if (_result == NULL && GC_locker::is_active_and_needs_gc()) {
set_gc_locked(); set_gc_locked();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册