8138862: Remove some unused code and subclasses in gcTaskManager.hpp/cpp
Reviewed-by: mgerdin, jwilhelm
This commit is contained in:
parent
be4747bc4d
commit
ef3a3a84bc
@ -48,8 +48,8 @@ const char* GCTask::Kind::to_string(kind value) {
|
|||||||
case ordinary_task:
|
case ordinary_task:
|
||||||
result = "ordinary task";
|
result = "ordinary task";
|
||||||
break;
|
break;
|
||||||
case barrier_task:
|
case wait_for_barrier_task:
|
||||||
result = "barrier task";
|
result = "wait for barrier task";
|
||||||
break;
|
break;
|
||||||
case noop_task:
|
case noop_task:
|
||||||
result = "noop task";
|
result = "noop task";
|
||||||
@ -378,16 +378,7 @@ SynchronizedGCTaskQueue::~SynchronizedGCTaskQueue() {
|
|||||||
GCTaskManager::GCTaskManager(uint workers) :
|
GCTaskManager::GCTaskManager(uint workers) :
|
||||||
_workers(workers),
|
_workers(workers),
|
||||||
_active_workers(0),
|
_active_workers(0),
|
||||||
_idle_workers(0),
|
_idle_workers(0) {
|
||||||
_ndc(NULL) {
|
|
||||||
initialize();
|
|
||||||
}
|
|
||||||
|
|
||||||
GCTaskManager::GCTaskManager(uint workers, NotifyDoneClosure* ndc) :
|
|
||||||
_workers(workers),
|
|
||||||
_active_workers(0),
|
|
||||||
_idle_workers(0),
|
|
||||||
_ndc(ndc) {
|
|
||||||
initialize();
|
initialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -437,7 +428,6 @@ void GCTaskManager::initialize() {
|
|||||||
}
|
}
|
||||||
reset_delivered_tasks();
|
reset_delivered_tasks();
|
||||||
reset_completed_tasks();
|
reset_completed_tasks();
|
||||||
reset_noop_tasks();
|
|
||||||
reset_barriers();
|
reset_barriers();
|
||||||
reset_emptied_queue();
|
reset_emptied_queue();
|
||||||
for (uint s = 0; s < workers(); s += 1) {
|
for (uint s = 0; s < workers(); s += 1) {
|
||||||
@ -671,7 +661,6 @@ GCTask* GCTaskManager::get_task(uint which) {
|
|||||||
// Just hand back a Noop task,
|
// Just hand back a Noop task,
|
||||||
// in case someone wanted us to release resources, or whatever.
|
// in case someone wanted us to release resources, or whatever.
|
||||||
result = noop_task();
|
result = noop_task();
|
||||||
increment_noop_tasks();
|
|
||||||
}
|
}
|
||||||
assert(result != NULL, "shouldn't have null task");
|
assert(result != NULL, "shouldn't have null task");
|
||||||
if (TraceGCTaskManager) {
|
if (TraceGCTaskManager) {
|
||||||
@ -706,11 +695,6 @@ void GCTaskManager::note_completion(uint which) {
|
|||||||
if (TraceGCTaskManager) {
|
if (TraceGCTaskManager) {
|
||||||
tty->print_cr(" GCTaskManager::note_completion(%u) done", which);
|
tty->print_cr(" GCTaskManager::note_completion(%u) done", which);
|
||||||
}
|
}
|
||||||
// Notify client that we are done.
|
|
||||||
NotifyDoneClosure* ndc = notify_done_closure();
|
|
||||||
if (ndc != NULL) {
|
|
||||||
ndc->notify(this);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (TraceGCTaskManager) {
|
if (TraceGCTaskManager) {
|
||||||
tty->print_cr(" GCTaskManager::note_completion(%u) (%s)->notify_all",
|
tty->print_cr(" GCTaskManager::note_completion(%u) (%s)->notify_all",
|
||||||
@ -751,7 +735,7 @@ uint GCTaskManager::decrement_busy_workers() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void GCTaskManager::release_all_resources() {
|
void GCTaskManager::release_all_resources() {
|
||||||
// If you want this to be done atomically, do it in a BarrierGCTask.
|
// If you want this to be done atomically, do it in a WaitForBarrierGCTask.
|
||||||
for (uint i = 0; i < workers(); i += 1) {
|
for (uint i = 0; i < workers(); i += 1) {
|
||||||
set_resource_flag(i, true);
|
set_resource_flag(i, true);
|
||||||
}
|
}
|
||||||
@ -813,23 +797,16 @@ void GCTaskManager::set_resource_flag(uint which, bool value) {
|
|||||||
// NoopGCTask
|
// NoopGCTask
|
||||||
//
|
//
|
||||||
|
|
||||||
NoopGCTask* NoopGCTask::create() {
|
|
||||||
NoopGCTask* result = new NoopGCTask(false);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
NoopGCTask* NoopGCTask::create_on_c_heap() {
|
NoopGCTask* NoopGCTask::create_on_c_heap() {
|
||||||
NoopGCTask* result = new(ResourceObj::C_HEAP, mtGC) NoopGCTask(true);
|
NoopGCTask* result = new(ResourceObj::C_HEAP, mtGC) NoopGCTask();
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void NoopGCTask::destroy(NoopGCTask* that) {
|
void NoopGCTask::destroy(NoopGCTask* that) {
|
||||||
if (that != NULL) {
|
if (that != NULL) {
|
||||||
that->destruct();
|
that->destruct();
|
||||||
if (that->is_c_heap_obj()) {
|
|
||||||
FreeHeap(that);
|
FreeHeap(that);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void NoopGCTask::destruct() {
|
void NoopGCTask::destruct() {
|
||||||
@ -908,74 +885,6 @@ void IdleGCTask::destruct() {
|
|||||||
// Nothing else to do.
|
// Nothing else to do.
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// BarrierGCTask
|
|
||||||
//
|
|
||||||
|
|
||||||
void BarrierGCTask::do_it(GCTaskManager* manager, uint which) {
|
|
||||||
// Wait for this to be the only busy worker.
|
|
||||||
// ??? I thought of having a StackObj class
|
|
||||||
// whose constructor would grab the lock and come to the barrier,
|
|
||||||
// and whose destructor would release the lock,
|
|
||||||
// but that seems like too much mechanism for two lines of code.
|
|
||||||
MutexLockerEx ml(manager->lock(), Mutex::_no_safepoint_check_flag);
|
|
||||||
do_it_internal(manager, which);
|
|
||||||
// Release manager->lock().
|
|
||||||
}
|
|
||||||
|
|
||||||
void BarrierGCTask::do_it_internal(GCTaskManager* manager, uint which) {
|
|
||||||
// Wait for this to be the only busy worker.
|
|
||||||
assert(manager->monitor()->owned_by_self(), "don't own the lock");
|
|
||||||
assert(manager->is_blocked(), "manager isn't blocked");
|
|
||||||
while (manager->busy_workers() > 1) {
|
|
||||||
if (TraceGCTaskManager) {
|
|
||||||
tty->print_cr("BarrierGCTask::do_it(%u) waiting on %u workers",
|
|
||||||
which, manager->busy_workers());
|
|
||||||
}
|
|
||||||
manager->monitor()->wait(Mutex::_no_safepoint_check_flag, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void BarrierGCTask::destruct() {
|
|
||||||
this->GCTask::destruct();
|
|
||||||
// Nothing else to do.
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// ReleasingBarrierGCTask
|
|
||||||
//
|
|
||||||
|
|
||||||
void ReleasingBarrierGCTask::do_it(GCTaskManager* manager, uint which) {
|
|
||||||
MutexLockerEx ml(manager->lock(), Mutex::_no_safepoint_check_flag);
|
|
||||||
do_it_internal(manager, which);
|
|
||||||
manager->release_all_resources();
|
|
||||||
// Release manager->lock().
|
|
||||||
}
|
|
||||||
|
|
||||||
void ReleasingBarrierGCTask::destruct() {
|
|
||||||
this->BarrierGCTask::destruct();
|
|
||||||
// Nothing else to do.
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// NotifyingBarrierGCTask
|
|
||||||
//
|
|
||||||
|
|
||||||
void NotifyingBarrierGCTask::do_it(GCTaskManager* manager, uint which) {
|
|
||||||
MutexLockerEx ml(manager->lock(), Mutex::_no_safepoint_check_flag);
|
|
||||||
do_it_internal(manager, which);
|
|
||||||
NotifyDoneClosure* ndc = notify_done_closure();
|
|
||||||
if (ndc != NULL) {
|
|
||||||
ndc->notify(manager);
|
|
||||||
}
|
|
||||||
// Release manager->lock().
|
|
||||||
}
|
|
||||||
|
|
||||||
void NotifyingBarrierGCTask::destruct() {
|
|
||||||
this->BarrierGCTask::destruct();
|
|
||||||
// Nothing else to do.
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// WaitForBarrierGCTask
|
// WaitForBarrierGCTask
|
||||||
//
|
//
|
||||||
@ -991,6 +900,7 @@ WaitForBarrierGCTask* WaitForBarrierGCTask::create_on_c_heap() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
WaitForBarrierGCTask::WaitForBarrierGCTask(bool on_c_heap) :
|
WaitForBarrierGCTask::WaitForBarrierGCTask(bool on_c_heap) :
|
||||||
|
GCTask(GCTask::Kind::wait_for_barrier_task),
|
||||||
_is_c_heap_obj(on_c_heap) {
|
_is_c_heap_obj(on_c_heap) {
|
||||||
_monitor = MonitorSupply::reserve();
|
_monitor = MonitorSupply::reserve();
|
||||||
set_should_wait(true);
|
set_should_wait(true);
|
||||||
@ -1028,7 +938,7 @@ void WaitForBarrierGCTask::destruct() {
|
|||||||
" monitor: " INTPTR_FORMAT,
|
" monitor: " INTPTR_FORMAT,
|
||||||
p2i(this), p2i(monitor()));
|
p2i(this), p2i(monitor()));
|
||||||
}
|
}
|
||||||
this->BarrierGCTask::destruct();
|
this->GCTask::destruct();
|
||||||
// Clean up that should be in the destructor,
|
// Clean up that should be in the destructor,
|
||||||
// except that ResourceMarks don't call destructors.
|
// except that ResourceMarks don't call destructors.
|
||||||
if (monitor() != NULL) {
|
if (monitor() != NULL) {
|
||||||
@ -1037,6 +947,19 @@ void WaitForBarrierGCTask::destruct() {
|
|||||||
_monitor = (Monitor*) 0xDEAD000F;
|
_monitor = (Monitor*) 0xDEAD000F;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void WaitForBarrierGCTask::do_it_internal(GCTaskManager* manager, uint which) {
|
||||||
|
// Wait for this to be the only busy worker.
|
||||||
|
assert(manager->monitor()->owned_by_self(), "don't own the lock");
|
||||||
|
assert(manager->is_blocked(), "manager isn't blocked");
|
||||||
|
while (manager->busy_workers() > 1) {
|
||||||
|
if (TraceGCTaskManager) {
|
||||||
|
tty->print_cr("WaitForBarrierGCTask::do_it(%u) waiting on %u workers",
|
||||||
|
which, manager->busy_workers());
|
||||||
|
}
|
||||||
|
manager->monitor()->wait(Mutex::_no_safepoint_check_flag, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void WaitForBarrierGCTask::do_it(GCTaskManager* manager, uint which) {
|
void WaitForBarrierGCTask::do_it(GCTaskManager* manager, uint which) {
|
||||||
if (TraceGCTaskManager) {
|
if (TraceGCTaskManager) {
|
||||||
tty->print_cr("[" INTPTR_FORMAT "]"
|
tty->print_cr("[" INTPTR_FORMAT "]"
|
||||||
|
@ -38,12 +38,8 @@ class GCTask;
|
|||||||
class GCTaskQueue;
|
class GCTaskQueue;
|
||||||
class SynchronizedGCTaskQueue;
|
class SynchronizedGCTaskQueue;
|
||||||
class GCTaskManager;
|
class GCTaskManager;
|
||||||
class NotifyDoneClosure;
|
|
||||||
// Some useful subclasses of GCTask. You can also make up your own.
|
// Some useful subclasses of GCTask. You can also make up your own.
|
||||||
class NoopGCTask;
|
class NoopGCTask;
|
||||||
class BarrierGCTask;
|
|
||||||
class ReleasingBarrierGCTask;
|
|
||||||
class NotifyingBarrierGCTask;
|
|
||||||
class WaitForBarrierGCTask;
|
class WaitForBarrierGCTask;
|
||||||
class IdleGCTask;
|
class IdleGCTask;
|
||||||
// A free list of Monitor*'s.
|
// A free list of Monitor*'s.
|
||||||
@ -64,7 +60,7 @@ public:
|
|||||||
enum kind {
|
enum kind {
|
||||||
unknown_task,
|
unknown_task,
|
||||||
ordinary_task,
|
ordinary_task,
|
||||||
barrier_task,
|
wait_for_barrier_task,
|
||||||
noop_task,
|
noop_task,
|
||||||
idle_task
|
idle_task
|
||||||
};
|
};
|
||||||
@ -105,7 +101,7 @@ public:
|
|||||||
return kind()==Kind::ordinary_task;
|
return kind()==Kind::ordinary_task;
|
||||||
}
|
}
|
||||||
bool is_barrier_task() const {
|
bool is_barrier_task() const {
|
||||||
return kind()==Kind::barrier_task;
|
return kind()==Kind::wait_for_barrier_task;
|
||||||
}
|
}
|
||||||
bool is_noop_task() const {
|
bool is_noop_task() const {
|
||||||
return kind()==Kind::noop_task;
|
return kind()==Kind::noop_task;
|
||||||
@ -276,23 +272,6 @@ protected:
|
|||||||
~SynchronizedGCTaskQueue();
|
~SynchronizedGCTaskQueue();
|
||||||
};
|
};
|
||||||
|
|
||||||
// This is an abstract base class for getting notifications
|
|
||||||
// when a GCTaskManager is done.
|
|
||||||
class NotifyDoneClosure : public CHeapObj<mtGC> {
|
|
||||||
public:
|
|
||||||
// The notification callback method.
|
|
||||||
virtual void notify(GCTaskManager* manager) = 0;
|
|
||||||
protected:
|
|
||||||
// Constructor.
|
|
||||||
NotifyDoneClosure() {
|
|
||||||
// Nothing to do.
|
|
||||||
}
|
|
||||||
// Virtual destructor because virtual methods.
|
|
||||||
virtual ~NotifyDoneClosure() {
|
|
||||||
// Nothing to do.
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Dynamic number of GC threads
|
// Dynamic number of GC threads
|
||||||
//
|
//
|
||||||
// GC threads wait in get_task() for work (i.e., a task) to perform.
|
// GC threads wait in get_task() for work (i.e., a task) to perform.
|
||||||
@ -365,7 +344,6 @@ class GCTaskManager : public CHeapObj<mtGC> {
|
|||||||
friend class IdleGCTask;
|
friend class IdleGCTask;
|
||||||
private:
|
private:
|
||||||
// Instance state.
|
// Instance state.
|
||||||
NotifyDoneClosure* _ndc; // Notify on completion.
|
|
||||||
const uint _workers; // Number of workers.
|
const uint _workers; // Number of workers.
|
||||||
Monitor* _monitor; // Notification of changes.
|
Monitor* _monitor; // Notification of changes.
|
||||||
SynchronizedGCTaskQueue* _queue; // Queue of tasks.
|
SynchronizedGCTaskQueue* _queue; // Queue of tasks.
|
||||||
@ -379,7 +357,6 @@ private:
|
|||||||
uint _barriers; // Count of barrier tasks.
|
uint _barriers; // Count of barrier tasks.
|
||||||
uint _emptied_queue; // Times we emptied the queue.
|
uint _emptied_queue; // Times we emptied the queue.
|
||||||
NoopGCTask* _noop_task; // The NoopGCTask instance.
|
NoopGCTask* _noop_task; // The NoopGCTask instance.
|
||||||
uint _noop_tasks; // Count of noop tasks.
|
|
||||||
WaitForBarrierGCTask* _idle_inactive_task;// Task for inactive workers
|
WaitForBarrierGCTask* _idle_inactive_task;// Task for inactive workers
|
||||||
volatile uint _idle_workers; // Number of idled workers
|
volatile uint _idle_workers; // Number of idled workers
|
||||||
public:
|
public:
|
||||||
@ -387,9 +364,6 @@ public:
|
|||||||
static GCTaskManager* create(uint workers) {
|
static GCTaskManager* create(uint workers) {
|
||||||
return new GCTaskManager(workers);
|
return new GCTaskManager(workers);
|
||||||
}
|
}
|
||||||
static GCTaskManager* create(uint workers, NotifyDoneClosure* ndc) {
|
|
||||||
return new GCTaskManager(workers, ndc);
|
|
||||||
}
|
|
||||||
static void destroy(GCTaskManager* that) {
|
static void destroy(GCTaskManager* that) {
|
||||||
if (that != NULL) {
|
if (that != NULL) {
|
||||||
delete that;
|
delete that;
|
||||||
@ -452,8 +426,6 @@ protected:
|
|||||||
// Constructors. Clients use factory, but there might be subclasses.
|
// Constructors. Clients use factory, but there might be subclasses.
|
||||||
// Create a GCTaskManager with the appropriate number of workers.
|
// Create a GCTaskManager with the appropriate number of workers.
|
||||||
GCTaskManager(uint workers);
|
GCTaskManager(uint workers);
|
||||||
// Create a GCTaskManager that calls back when there's no more work.
|
|
||||||
GCTaskManager(uint workers, NotifyDoneClosure* ndc);
|
|
||||||
// Make virtual if necessary.
|
// Make virtual if necessary.
|
||||||
~GCTaskManager();
|
~GCTaskManager();
|
||||||
// Accessors.
|
// Accessors.
|
||||||
@ -469,9 +441,6 @@ protected:
|
|||||||
// Sets the number of threads that will be used in a collection
|
// Sets the number of threads that will be used in a collection
|
||||||
void set_active_gang();
|
void set_active_gang();
|
||||||
|
|
||||||
NotifyDoneClosure* notify_done_closure() const {
|
|
||||||
return _ndc;
|
|
||||||
}
|
|
||||||
SynchronizedGCTaskQueue* queue() const {
|
SynchronizedGCTaskQueue* queue() const {
|
||||||
return _queue;
|
return _queue;
|
||||||
}
|
}
|
||||||
@ -540,17 +509,6 @@ protected:
|
|||||||
void reset_emptied_queue() {
|
void reset_emptied_queue() {
|
||||||
_emptied_queue = 0;
|
_emptied_queue = 0;
|
||||||
}
|
}
|
||||||
// Count of the number of noop tasks we've handed out,
|
|
||||||
// e.g., to handle resource release requests.
|
|
||||||
uint noop_tasks() const {
|
|
||||||
return _noop_tasks;
|
|
||||||
}
|
|
||||||
void increment_noop_tasks() {
|
|
||||||
_noop_tasks += 1;
|
|
||||||
}
|
|
||||||
void reset_noop_tasks() {
|
|
||||||
_noop_tasks = 0;
|
|
||||||
}
|
|
||||||
void increment_idle_workers() {
|
void increment_idle_workers() {
|
||||||
_idle_workers++;
|
_idle_workers++;
|
||||||
}
|
}
|
||||||
@ -575,11 +533,8 @@ protected:
|
|||||||
// A noop task that does nothing,
|
// A noop task that does nothing,
|
||||||
// except take us around the GCTaskThread loop.
|
// except take us around the GCTaskThread loop.
|
||||||
class NoopGCTask : public GCTask {
|
class NoopGCTask : public GCTask {
|
||||||
private:
|
|
||||||
const bool _is_c_heap_obj; // Is this a CHeapObj?
|
|
||||||
public:
|
public:
|
||||||
// Factory create and destroy methods.
|
// Factory create and destroy methods.
|
||||||
static NoopGCTask* create();
|
|
||||||
static NoopGCTask* create_on_c_heap();
|
static NoopGCTask* create_on_c_heap();
|
||||||
static void destroy(NoopGCTask* that);
|
static void destroy(NoopGCTask* that);
|
||||||
|
|
||||||
@ -590,113 +545,16 @@ public:
|
|||||||
}
|
}
|
||||||
protected:
|
protected:
|
||||||
// Constructor.
|
// Constructor.
|
||||||
NoopGCTask(bool on_c_heap) :
|
NoopGCTask() :
|
||||||
GCTask(GCTask::Kind::noop_task),
|
GCTask(GCTask::Kind::noop_task) { }
|
||||||
_is_c_heap_obj(on_c_heap) {
|
|
||||||
// Nothing to do.
|
|
||||||
}
|
|
||||||
// Destructor-like method.
|
|
||||||
void destruct();
|
|
||||||
// Accessors.
|
|
||||||
bool is_c_heap_obj() const {
|
|
||||||
return _is_c_heap_obj;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// A BarrierGCTask blocks other tasks from starting,
|
|
||||||
// and waits until it is the only task running.
|
|
||||||
class BarrierGCTask : public GCTask {
|
|
||||||
public:
|
|
||||||
// Factory create and destroy methods.
|
|
||||||
static BarrierGCTask* create() {
|
|
||||||
return new BarrierGCTask();
|
|
||||||
}
|
|
||||||
static void destroy(BarrierGCTask* that) {
|
|
||||||
if (that != NULL) {
|
|
||||||
that->destruct();
|
|
||||||
delete that;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Methods from GCTask.
|
|
||||||
void do_it(GCTaskManager* manager, uint which);
|
|
||||||
protected:
|
|
||||||
// Constructor. Clients use factory, but there might be subclasses.
|
|
||||||
BarrierGCTask() :
|
|
||||||
GCTask(GCTask::Kind::barrier_task) {
|
|
||||||
// Nothing to do.
|
|
||||||
}
|
|
||||||
// Destructor-like method.
|
|
||||||
void destruct();
|
|
||||||
|
|
||||||
virtual char* name() { return (char *)"barrier task"; }
|
|
||||||
// Methods.
|
|
||||||
// Wait for this to be the only task running.
|
|
||||||
void do_it_internal(GCTaskManager* manager, uint which);
|
|
||||||
};
|
|
||||||
|
|
||||||
// A ReleasingBarrierGCTask is a BarrierGCTask
|
|
||||||
// that tells all the tasks to release their resource areas.
|
|
||||||
class ReleasingBarrierGCTask : public BarrierGCTask {
|
|
||||||
public:
|
|
||||||
// Factory create and destroy methods.
|
|
||||||
static ReleasingBarrierGCTask* create() {
|
|
||||||
return new ReleasingBarrierGCTask();
|
|
||||||
}
|
|
||||||
static void destroy(ReleasingBarrierGCTask* that) {
|
|
||||||
if (that != NULL) {
|
|
||||||
that->destruct();
|
|
||||||
delete that;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Methods from GCTask.
|
|
||||||
void do_it(GCTaskManager* manager, uint which);
|
|
||||||
protected:
|
|
||||||
// Constructor. Clients use factory, but there might be subclasses.
|
|
||||||
ReleasingBarrierGCTask() :
|
|
||||||
BarrierGCTask() {
|
|
||||||
// Nothing to do.
|
|
||||||
}
|
|
||||||
// Destructor-like method.
|
// Destructor-like method.
|
||||||
void destruct();
|
void destruct();
|
||||||
};
|
};
|
||||||
|
|
||||||
// A NotifyingBarrierGCTask is a BarrierGCTask
|
// A WaitForBarrierGCTask is a GCTask
|
||||||
// that calls a notification method when it is the only task running.
|
|
||||||
class NotifyingBarrierGCTask : public BarrierGCTask {
|
|
||||||
private:
|
|
||||||
// Instance state.
|
|
||||||
NotifyDoneClosure* _ndc; // The callback object.
|
|
||||||
public:
|
|
||||||
// Factory create and destroy methods.
|
|
||||||
static NotifyingBarrierGCTask* create(NotifyDoneClosure* ndc) {
|
|
||||||
return new NotifyingBarrierGCTask(ndc);
|
|
||||||
}
|
|
||||||
static void destroy(NotifyingBarrierGCTask* that) {
|
|
||||||
if (that != NULL) {
|
|
||||||
that->destruct();
|
|
||||||
delete that;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Methods from GCTask.
|
|
||||||
void do_it(GCTaskManager* manager, uint which);
|
|
||||||
protected:
|
|
||||||
// Constructor. Clients use factory, but there might be subclasses.
|
|
||||||
NotifyingBarrierGCTask(NotifyDoneClosure* ndc) :
|
|
||||||
BarrierGCTask(),
|
|
||||||
_ndc(ndc) {
|
|
||||||
assert(notify_done_closure() != NULL, "can't notify on NULL");
|
|
||||||
}
|
|
||||||
// Destructor-like method.
|
|
||||||
void destruct();
|
|
||||||
// Accessor.
|
|
||||||
NotifyDoneClosure* notify_done_closure() const { return _ndc; }
|
|
||||||
};
|
|
||||||
|
|
||||||
// A WaitForBarrierGCTask is a BarrierGCTask
|
|
||||||
// with a method you can call to wait until
|
// with a method you can call to wait until
|
||||||
// the BarrierGCTask is done.
|
// the BarrierGCTask is done.
|
||||||
// This may cover many of the uses of NotifyingBarrierGCTasks.
|
class WaitForBarrierGCTask : public GCTask {
|
||||||
class WaitForBarrierGCTask : public BarrierGCTask {
|
|
||||||
friend class GCTaskManager;
|
friend class GCTaskManager;
|
||||||
friend class IdleGCTask;
|
friend class IdleGCTask;
|
||||||
private:
|
private:
|
||||||
@ -722,6 +580,11 @@ protected:
|
|||||||
WaitForBarrierGCTask(bool on_c_heap);
|
WaitForBarrierGCTask(bool on_c_heap);
|
||||||
// Destructor-like method.
|
// Destructor-like method.
|
||||||
void destruct();
|
void destruct();
|
||||||
|
|
||||||
|
// Methods.
|
||||||
|
// Wait for this to be the only task running.
|
||||||
|
void do_it_internal(GCTaskManager* manager, uint which);
|
||||||
|
|
||||||
// Accessors.
|
// Accessors.
|
||||||
Monitor* monitor() const {
|
Monitor* monitor() const {
|
||||||
return _monitor;
|
return _monitor;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user