8072621: Clean up around VM_GC_Operations

Reviewed-by: brutisso, jmasa
This commit is contained in:
Marcus Larsson 2015-02-13 09:48:49 +01:00
parent 20bfd4cf7c
commit 7727fe0044
12 changed files with 84 additions and 88 deletions

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -129,8 +129,8 @@ class VM_CMS_Final_Remark: public VM_CMS_Operation {
// GenCollectedHeap heap. // GenCollectedHeap heap.
class VM_GenCollectFullConcurrent: public VM_GC_Operation { class VM_GenCollectFullConcurrent: public VM_GC_Operation {
public: public:
VM_GenCollectFullConcurrent(unsigned int gc_count_before, VM_GenCollectFullConcurrent(uint gc_count_before,
unsigned int full_gc_count_before, uint full_gc_count_before,
GCCause::Cause gc_cause) GCCause::Cause gc_cause)
: VM_GC_Operation(gc_count_before, gc_cause, full_gc_count_before, true /* full */) : VM_GC_Operation(gc_count_before, gc_cause, full_gc_count_before, true /* full */)
{ {

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -333,7 +333,7 @@ void YoungList::print() {
HeapRegion* lists[] = {_head, _survivor_head}; HeapRegion* lists[] = {_head, _survivor_head};
const char* names[] = {"YOUNG", "SURVIVOR"}; const char* names[] = {"YOUNG", "SURVIVOR"};
for (unsigned int list = 0; list < ARRAY_SIZE(lists); ++list) { for (uint list = 0; list < ARRAY_SIZE(lists); ++list) {
gclog_or_tty->print_cr("%s LIST CONTENTS", names[list]); gclog_or_tty->print_cr("%s LIST CONTENTS", names[list]);
HeapRegion *curr = lists[list]; HeapRegion *curr = lists[list];
if (curr == NULL) if (curr == NULL)
@ -765,8 +765,8 @@ HeapWord* G1CollectedHeap::allocate_new_tlab(size_t word_size) {
assert_heap_not_locked_and_not_at_safepoint(); assert_heap_not_locked_and_not_at_safepoint();
assert(!is_humongous(word_size), "we do not allow humongous TLABs"); assert(!is_humongous(word_size), "we do not allow humongous TLABs");
unsigned int dummy_gc_count_before; uint dummy_gc_count_before;
int dummy_gclocker_retry_count = 0; uint dummy_gclocker_retry_count = 0;
return attempt_allocation(word_size, &dummy_gc_count_before, &dummy_gclocker_retry_count); return attempt_allocation(word_size, &dummy_gc_count_before, &dummy_gclocker_retry_count);
} }
@ -776,8 +776,8 @@ G1CollectedHeap::mem_allocate(size_t word_size,
assert_heap_not_locked_and_not_at_safepoint(); assert_heap_not_locked_and_not_at_safepoint();
// Loop until the allocation is satisfied, or unsatisfied after GC. // Loop until the allocation is satisfied, or unsatisfied after GC.
for (int try_count = 1, gclocker_retry_count = 0; /* we'll return */; try_count += 1) { for (uint try_count = 1, gclocker_retry_count = 0; /* we'll return */; try_count += 1) {
unsigned int gc_count_before; uint gc_count_before;
HeapWord* result = NULL; HeapWord* result = NULL;
if (!is_humongous(word_size)) { if (!is_humongous(word_size)) {
@ -829,8 +829,8 @@ G1CollectedHeap::mem_allocate(size_t word_size,
HeapWord* G1CollectedHeap::attempt_allocation_slow(size_t word_size, HeapWord* G1CollectedHeap::attempt_allocation_slow(size_t word_size,
AllocationContext_t context, AllocationContext_t context,
unsigned int *gc_count_before_ret, uint* gc_count_before_ret,
int* gclocker_retry_count_ret) { uint* gclocker_retry_count_ret) {
// Make sure you read the note in attempt_allocation_humongous(). // Make sure you read the note in attempt_allocation_humongous().
assert_heap_not_locked_and_not_at_safepoint(); assert_heap_not_locked_and_not_at_safepoint();
@ -847,7 +847,7 @@ HeapWord* G1CollectedHeap::attempt_allocation_slow(size_t word_size,
HeapWord* result = NULL; HeapWord* result = NULL;
for (int try_count = 1; /* we'll return */; try_count += 1) { for (int try_count = 1; /* we'll return */; try_count += 1) {
bool should_try_gc; bool should_try_gc;
unsigned int gc_count_before; uint gc_count_before;
{ {
MutexLockerEx x(Heap_lock); MutexLockerEx x(Heap_lock);
@ -945,8 +945,8 @@ HeapWord* G1CollectedHeap::attempt_allocation_slow(size_t word_size,
} }
HeapWord* G1CollectedHeap::attempt_allocation_humongous(size_t word_size, HeapWord* G1CollectedHeap::attempt_allocation_humongous(size_t word_size,
unsigned int * gc_count_before_ret, uint* gc_count_before_ret,
int* gclocker_retry_count_ret) { uint* gclocker_retry_count_ret) {
// The structure of this method has a lot of similarities to // The structure of this method has a lot of similarities to
// attempt_allocation_slow(). The reason these two were not merged // attempt_allocation_slow(). The reason these two were not merged
// into a single one is that such a method would require several "if // into a single one is that such a method would require several "if
@ -979,7 +979,7 @@ HeapWord* G1CollectedHeap::attempt_allocation_humongous(size_t word_size,
HeapWord* result = NULL; HeapWord* result = NULL;
for (int try_count = 1; /* we'll return */; try_count += 1) { for (int try_count = 1; /* we'll return */; try_count += 1) {
bool should_try_gc; bool should_try_gc;
unsigned int gc_count_before; uint gc_count_before;
{ {
MutexLockerEx x(Heap_lock); MutexLockerEx x(Heap_lock);
@ -1815,7 +1815,7 @@ G1CollectedHeap::G1CollectedHeap(G1CollectorPolicy* policy_) :
assert(n_rem_sets > 0, "Invariant."); assert(n_rem_sets > 0, "Invariant.");
_worker_cset_start_region = NEW_C_HEAP_ARRAY(HeapRegion*, n_queues, mtGC); _worker_cset_start_region = NEW_C_HEAP_ARRAY(HeapRegion*, n_queues, mtGC);
_worker_cset_start_region_time_stamp = NEW_C_HEAP_ARRAY(unsigned int, n_queues, mtGC); _worker_cset_start_region_time_stamp = NEW_C_HEAP_ARRAY(uint, n_queues, mtGC);
_evacuation_failed_info_array = NEW_C_HEAP_ARRAY(EvacuationFailedInfo, n_queues, mtGC); _evacuation_failed_info_array = NEW_C_HEAP_ARRAY(EvacuationFailedInfo, n_queues, mtGC);
for (int i = 0; i < n_queues; i++) { for (int i = 0; i < n_queues; i++) {
@ -2396,9 +2396,9 @@ G1YCType G1CollectedHeap::yc_type() {
void G1CollectedHeap::collect(GCCause::Cause cause) { void G1CollectedHeap::collect(GCCause::Cause cause) {
assert_heap_not_locked(); assert_heap_not_locked();
unsigned int gc_count_before; uint gc_count_before;
unsigned int old_marking_count_before; uint old_marking_count_before;
unsigned int full_gc_count_before; uint full_gc_count_before;
bool retry_gc; bool retry_gc;
do { do {
@ -3418,7 +3418,7 @@ void G1CollectedHeap::gc_epilogue(bool full) {
} }
HeapWord* G1CollectedHeap::do_collection_pause(size_t word_size, HeapWord* G1CollectedHeap::do_collection_pause(size_t word_size,
unsigned int gc_count_before, uint gc_count_before,
bool* succeeded, bool* succeeded,
GCCause::Cause gc_cause) { GCCause::Cause gc_cause) {
assert_heap_not_locked_and_not_at_safepoint(); assert_heap_not_locked_and_not_at_safepoint();

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -325,11 +325,11 @@ private:
// Keeps track of how many "old marking cycles" (i.e., Full GCs or // Keeps track of how many "old marking cycles" (i.e., Full GCs or
// concurrent cycles) we have started. // concurrent cycles) we have started.
volatile unsigned int _old_marking_cycles_started; volatile uint _old_marking_cycles_started;
// Keeps track of how many "old marking cycles" (i.e., Full GCs or // Keeps track of how many "old marking cycles" (i.e., Full GCs or
// concurrent cycles) we have completed. // concurrent cycles) we have completed.
volatile unsigned int _old_marking_cycles_completed; volatile uint _old_marking_cycles_completed;
bool _concurrent_cycle_started; bool _concurrent_cycle_started;
bool _heap_summary_sent; bool _heap_summary_sent;
@ -497,22 +497,22 @@ protected:
// the mutator alloc region without taking the Heap_lock. This // the mutator alloc region without taking the Heap_lock. This
// should only be used for non-humongous allocations. // should only be used for non-humongous allocations.
inline HeapWord* attempt_allocation(size_t word_size, inline HeapWord* attempt_allocation(size_t word_size,
unsigned int* gc_count_before_ret, uint* gc_count_before_ret,
int* gclocker_retry_count_ret); uint* gclocker_retry_count_ret);
// Second-level mutator allocation attempt: take the Heap_lock and // Second-level mutator allocation attempt: take the Heap_lock and
// retry the allocation attempt, potentially scheduling a GC // retry the allocation attempt, potentially scheduling a GC
// pause. This should only be used for non-humongous allocations. // pause. This should only be used for non-humongous allocations.
HeapWord* attempt_allocation_slow(size_t word_size, HeapWord* attempt_allocation_slow(size_t word_size,
AllocationContext_t context, AllocationContext_t context,
unsigned int* gc_count_before_ret, uint* gc_count_before_ret,
int* gclocker_retry_count_ret); uint* gclocker_retry_count_ret);
// Takes the Heap_lock and attempts a humongous allocation. It can // Takes the Heap_lock and attempts a humongous allocation. It can
// potentially schedule a GC pause. // potentially schedule a GC pause.
HeapWord* attempt_allocation_humongous(size_t word_size, HeapWord* attempt_allocation_humongous(size_t word_size,
unsigned int* gc_count_before_ret, uint* gc_count_before_ret,
int* gclocker_retry_count_ret); uint* gclocker_retry_count_ret);
// Allocation attempt that should be called during safepoints (e.g., // Allocation attempt that should be called during safepoints (e.g.,
// at the end of a successful GC). expect_null_mutator_alloc_region // at the end of a successful GC). expect_null_mutator_alloc_region
@ -686,7 +686,7 @@ public:
// +ExplicitGCInvokesConcurrent). // +ExplicitGCInvokesConcurrent).
void increment_old_marking_cycles_completed(bool concurrent); void increment_old_marking_cycles_completed(bool concurrent);
unsigned int old_marking_cycles_completed() { uint old_marking_cycles_completed() {
return _old_marking_cycles_completed; return _old_marking_cycles_completed;
} }
@ -745,7 +745,7 @@ protected:
// methods that call do_collection_pause() release the Heap_lock // methods that call do_collection_pause() release the Heap_lock
// before the call, so it's easy to read gc_count_before just before. // before the call, so it's easy to read gc_count_before just before.
HeapWord* do_collection_pause(size_t word_size, HeapWord* do_collection_pause(size_t word_size,
unsigned int gc_count_before, uint gc_count_before,
bool* succeeded, bool* succeeded,
GCCause::Cause gc_cause); GCCause::Cause gc_cause);
@ -981,7 +981,7 @@ protected:
// The heap region entry for a given worker is valid iff // The heap region entry for a given worker is valid iff
// the associated time stamp value matches the current value // the associated time stamp value matches the current value
// of G1CollectedHeap::_gc_time_stamp. // of G1CollectedHeap::_gc_time_stamp.
unsigned int* _worker_cset_start_region_time_stamp; uint* _worker_cset_start_region_time_stamp;
enum G1H_process_roots_tasks { enum G1H_process_roots_tasks {
G1H_PS_filter_satb_buffers, G1H_PS_filter_satb_buffers,

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -131,8 +131,8 @@ inline bool G1CollectedHeap::obj_in_cs(oop obj) {
} }
inline HeapWord* G1CollectedHeap::attempt_allocation(size_t word_size, inline HeapWord* G1CollectedHeap::attempt_allocation(size_t word_size,
unsigned int* gc_count_before_ret, uint* gc_count_before_ret,
int* gclocker_retry_count_ret) { uint* gclocker_retry_count_ret) {
assert_heap_not_locked_and_not_at_safepoint(); assert_heap_not_locked_and_not_at_safepoint();
assert(!is_humongous(word_size), "attempt_allocation() should not " assert(!is_humongous(word_size), "attempt_allocation() should not "
"be called for humongous allocation requests"); "be called for humongous allocation requests");

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -34,8 +34,7 @@
#include "gc_implementation/g1/vm_operations_g1.hpp" #include "gc_implementation/g1/vm_operations_g1.hpp"
#include "runtime/interfaceSupport.hpp" #include "runtime/interfaceSupport.hpp"
VM_G1CollectForAllocation::VM_G1CollectForAllocation( VM_G1CollectForAllocation::VM_G1CollectForAllocation(uint gc_count_before,
unsigned int gc_count_before,
size_t word_size) size_t word_size)
: VM_G1OperationWithAllocRequest(gc_count_before, word_size, : VM_G1OperationWithAllocRequest(gc_count_before, word_size,
GCCause::_allocation_failure) { GCCause::_allocation_failure) {
@ -57,8 +56,7 @@ void VM_G1CollectFull::doit() {
g1h->do_full_collection(false /* clear_all_soft_refs */); g1h->do_full_collection(false /* clear_all_soft_refs */);
} }
VM_G1IncCollectionPause::VM_G1IncCollectionPause( VM_G1IncCollectionPause::VM_G1IncCollectionPause(uint gc_count_before,
unsigned int gc_count_before,
size_t word_size, size_t word_size,
bool should_initiate_conc_mark, bool should_initiate_conc_mark,
double target_pause_time_ms, double target_pause_time_ms,

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -44,7 +44,7 @@ protected:
AllocationContext_t _allocation_context; AllocationContext_t _allocation_context;
public: public:
VM_G1OperationWithAllocRequest(unsigned int gc_count_before, VM_G1OperationWithAllocRequest(uint gc_count_before,
size_t word_size, size_t word_size,
GCCause::Cause gc_cause) GCCause::Cause gc_cause)
: VM_GC_Operation(gc_count_before, gc_cause), : VM_GC_Operation(gc_count_before, gc_cause),
@ -57,8 +57,8 @@ public:
class VM_G1CollectFull: public VM_GC_Operation { class VM_G1CollectFull: public VM_GC_Operation {
public: public:
VM_G1CollectFull(unsigned int gc_count_before, VM_G1CollectFull(uint gc_count_before,
unsigned int full_gc_count_before, uint full_gc_count_before,
GCCause::Cause cause) GCCause::Cause cause)
: VM_GC_Operation(gc_count_before, cause, full_gc_count_before, true) { } : VM_GC_Operation(gc_count_before, cause, full_gc_count_before, true) { }
virtual VMOp_Type type() const { return VMOp_G1CollectFull; } virtual VMOp_Type type() const { return VMOp_G1CollectFull; }
@ -70,7 +70,7 @@ public:
class VM_G1CollectForAllocation: public VM_G1OperationWithAllocRequest { class VM_G1CollectForAllocation: public VM_G1OperationWithAllocRequest {
public: public:
VM_G1CollectForAllocation(unsigned int gc_count_before, VM_G1CollectForAllocation(uint gc_count_before,
size_t word_size); size_t word_size);
virtual VMOp_Type type() const { return VMOp_G1CollectForAllocation; } virtual VMOp_Type type() const { return VMOp_G1CollectForAllocation; }
virtual void doit(); virtual void doit();
@ -84,9 +84,9 @@ private:
bool _should_initiate_conc_mark; bool _should_initiate_conc_mark;
bool _should_retry_gc; bool _should_retry_gc;
double _target_pause_time_ms; double _target_pause_time_ms;
unsigned int _old_marking_cycles_completed_before; uint _old_marking_cycles_completed_before;
public: public:
VM_G1IncCollectionPause(unsigned int gc_count_before, VM_G1IncCollectionPause(uint gc_count_before,
size_t word_size, size_t word_size,
bool should_initiate_conc_mark, bool should_initiate_conc_mark,
double target_pause_time_ms, double target_pause_time_ms,

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -260,7 +260,7 @@ HeapWord* ParallelScavengeHeap::mem_allocate(
uint loop_count = 0; uint loop_count = 0;
uint gc_count = 0; uint gc_count = 0;
int gclocker_stalled_count = 0; uint gclocker_stalled_count = 0;
while (result == NULL) { while (result == NULL) {
// We don't want to have multiple collections for a single filled generation. // We don't want to have multiple collections for a single filled generation.
@ -520,8 +520,8 @@ void ParallelScavengeHeap::collect(GCCause::Cause cause) {
assert(!Heap_lock->owned_by_self(), assert(!Heap_lock->owned_by_self(),
"this thread should not own the Heap_lock"); "this thread should not own the Heap_lock");
unsigned int gc_count = 0; uint gc_count = 0;
unsigned int full_gc_count = 0; uint full_gc_count = 0;
{ {
MutexLocker ml(Heap_lock); MutexLocker ml(Heap_lock);
// This value is guarded by the Heap_lock // This value is guarded by the Heap_lock

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -33,7 +33,7 @@
// The following methods are used by the parallel scavenge collector // The following methods are used by the parallel scavenge collector
VM_ParallelGCFailedAllocation::VM_ParallelGCFailedAllocation(size_t size, VM_ParallelGCFailedAllocation::VM_ParallelGCFailedAllocation(size_t size,
unsigned int gc_count) : uint gc_count) :
VM_GC_Operation(gc_count, GCCause::_allocation_failure), VM_GC_Operation(gc_count, GCCause::_allocation_failure),
_size(size), _size(size),
_result(NULL) _result(NULL)
@ -55,8 +55,8 @@ void VM_ParallelGCFailedAllocation::doit() {
} }
// Only used for System.gc() calls // Only used for System.gc() calls
VM_ParallelGCSystemGC::VM_ParallelGCSystemGC(unsigned int gc_count, VM_ParallelGCSystemGC::VM_ParallelGCSystemGC(uint gc_count,
unsigned int full_gc_count, uint full_gc_count,
GCCause::Cause gc_cause) : GCCause::Cause gc_cause) :
VM_GC_Operation(gc_count, gc_cause, full_gc_count, true /* full */) VM_GC_Operation(gc_count, gc_cause, full_gc_count, true /* full */)
{ {

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2007, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -35,7 +35,7 @@ class VM_ParallelGCFailedAllocation: public VM_GC_Operation {
HeapWord* _result; HeapWord* _result;
public: public:
VM_ParallelGCFailedAllocation(size_t size, unsigned int gc_count); VM_ParallelGCFailedAllocation(size_t size, uint gc_count);
virtual VMOp_Type type() const { virtual VMOp_Type type() const {
return VMOp_ParallelGCFailedAllocation; return VMOp_ParallelGCFailedAllocation;
@ -47,8 +47,7 @@ class VM_ParallelGCFailedAllocation: public VM_GC_Operation {
class VM_ParallelGCSystemGC: public VM_GC_Operation { class VM_ParallelGCSystemGC: public VM_GC_Operation {
public: public:
VM_ParallelGCSystemGC(unsigned int gc_count, unsigned int full_gc_count, VM_ParallelGCSystemGC(uint gc_count, uint full_gc_count, GCCause::Cause gc_cause);
GCCause::Cause gc_cause);
virtual VMOp_Type type() const { return VMOp_ParallelGCSystemGC; } virtual VMOp_Type type() const { return VMOp_ParallelGCSystemGC; }
virtual void doit(); virtual void doit();
}; };

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -67,8 +67,8 @@
class VM_GC_Operation: public VM_Operation { class VM_GC_Operation: public VM_Operation {
protected: protected:
BasicLock _pending_list_basic_lock; // for refs pending list notification (PLL) BasicLock _pending_list_basic_lock; // for refs pending list notification (PLL)
unsigned int _gc_count_before; // gc count before acquiring PLL uint _gc_count_before; // gc count before acquiring PLL
unsigned int _full_gc_count_before; // full gc count before acquiring PLL uint _full_gc_count_before; // full gc count before acquiring PLL
bool _full; // whether a "full" collection bool _full; // whether a "full" collection
bool _prologue_succeeded; // whether doit_prologue succeeded bool _prologue_succeeded; // whether doit_prologue succeeded
GCCause::Cause _gc_cause; // the putative cause for this gc op GCCause::Cause _gc_cause; // the putative cause for this gc op
@ -81,9 +81,9 @@ class VM_GC_Operation: public VM_Operation {
void release_and_notify_pending_list_lock(); void release_and_notify_pending_list_lock();
public: public:
VM_GC_Operation(unsigned int gc_count_before, VM_GC_Operation(uint gc_count_before,
GCCause::Cause _cause, GCCause::Cause _cause,
unsigned int full_gc_count_before = 0, uint full_gc_count_before = 0,
bool full = false) { bool full = false) {
_full = full; _full = full;
_prologue_succeeded = false; _prologue_succeeded = false;
@ -169,7 +169,7 @@ class VM_GenCollectForAllocation: public VM_GC_Operation {
public: public:
VM_GenCollectForAllocation(size_t size, VM_GenCollectForAllocation(size_t size,
bool tlab, bool tlab,
unsigned int gc_count_before) uint gc_count_before)
: VM_GC_Operation(gc_count_before, GCCause::_allocation_failure), : VM_GC_Operation(gc_count_before, GCCause::_allocation_failure),
_size(size), _size(size),
_tlab(tlab) { _tlab(tlab) {
@ -181,15 +181,14 @@ class VM_GenCollectForAllocation: public VM_GC_Operation {
HeapWord* result() const { return _res; } HeapWord* result() const { return _res; }
}; };
// VM operation to invoke a collection of the heap as a // VM operation to invoke a collection of the heap as a
// GenCollectedHeap heap. // GenCollectedHeap heap.
class VM_GenCollectFull: public VM_GC_Operation { class VM_GenCollectFull: public VM_GC_Operation {
private: private:
int _max_level; int _max_level;
public: public:
VM_GenCollectFull(unsigned int gc_count_before, VM_GenCollectFull(uint gc_count_before,
unsigned int full_gc_count_before, uint full_gc_count_before,
GCCause::Cause gc_cause, GCCause::Cause gc_cause,
int max_level) int max_level)
: VM_GC_Operation(gc_count_before, gc_cause, full_gc_count_before, true /* full */), : VM_GC_Operation(gc_count_before, gc_cause, full_gc_count_before, true /* full */),
@ -208,8 +207,8 @@ class VM_CollectForMetadataAllocation: public VM_GC_Operation {
public: public:
VM_CollectForMetadataAllocation(ClassLoaderData* loader_data, VM_CollectForMetadataAllocation(ClassLoaderData* loader_data,
size_t size, Metaspace::MetadataType mdtype, size_t size, Metaspace::MetadataType mdtype,
unsigned int gc_count_before, uint gc_count_before,
unsigned int full_gc_count_before, uint full_gc_count_before,
GCCause::Cause gc_cause) GCCause::Cause gc_cause)
: VM_GC_Operation(gc_count_before, gc_cause, full_gc_count_before, true), : VM_GC_Operation(gc_count_before, gc_cause, full_gc_count_before, true),
_loader_data(loader_data), _size(size), _mdtype(mdtype), _result(NULL) { _loader_data(loader_data), _size(size), _mdtype(mdtype), _result(NULL) {

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -597,7 +597,7 @@ HeapWord* GenCollectorPolicy::mem_allocate_work(size_t size,
HeapWord* result = NULL; HeapWord* result = NULL;
// Loop until the allocation is satisfied, or unsatisfied after GC. // Loop until the allocation is satisfied, or unsatisfied after GC.
for (int try_count = 1, gclocker_stalled_count = 0; /* return or throw */; try_count += 1) { for (uint try_count = 1, gclocker_stalled_count = 0; /* return or throw */; try_count += 1) {
HandleMark hm; // Discard any handles allocated in each iteration. HandleMark hm; // Discard any handles allocated in each iteration.
// First allocation attempt is lock-free. // First allocation attempt is lock-free.
@ -611,7 +611,7 @@ HeapWord* GenCollectorPolicy::mem_allocate_work(size_t size,
return result; return result;
} }
} }
unsigned int gc_count_before; // Read inside the Heap_lock locked region. uint gc_count_before; // Read inside the Heap_lock locked region.
{ {
MutexLocker ml(Heap_lock); MutexLocker ml(Heap_lock);
if (PrintGC && Verbose) { if (PrintGC && Verbose) {

View File

@ -1516,7 +1516,7 @@ class CommandLineFlags {
"How much the GC can expand the eden by while the GC locker " \ "How much the GC can expand the eden by while the GC locker " \
"is active (as a percentage)") \ "is active (as a percentage)") \
\ \
diagnostic(intx, GCLockerRetryAllocationCount, 2, \ diagnostic(uintx, GCLockerRetryAllocationCount, 2, \
"Number of times to retry allocations when " \ "Number of times to retry allocations when " \
"blocked by the GC locker") \ "blocked by the GC locker") \
\ \