2008-06-05 15:57:56 -07:00
|
|
|
/*
|
2015-04-15 16:37:57 -04:00
|
|
|
* Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
|
2008-06-05 15:57:56 -07:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
2010-05-27 19:08:38 -07:00
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
2008-06-05 15:57:56 -07:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2015-11-06 16:30:40 -05:00
|
|
|
#ifndef SHARE_VM_GC_G1_SATBMARKQUEUE_HPP
|
|
|
|
#define SHARE_VM_GC_G1_SATBMARKQUEUE_HPP
|
2010-11-23 13:22:55 -08:00
|
|
|
|
2015-05-13 15:16:06 +02:00
|
|
|
#include "gc/g1/ptrQueue.hpp"
|
2015-05-01 17:38:12 -04:00
|
|
|
#include "memory/allocation.hpp"
|
2010-11-23 13:22:55 -08:00
|
|
|
|
2008-06-05 15:57:56 -07:00
|
|
|
class JavaThread;
|
2012-01-10 18:58:13 -05:00
|
|
|
class SATBMarkQueueSet;
|
2008-06-05 15:57:56 -07:00
|
|
|
|
2015-05-01 17:38:12 -04:00
|
|
|
// Base class for processing the contents of a SATB buffer.
|
|
|
|
class SATBBufferClosure : public StackObj {
|
|
|
|
protected:
|
|
|
|
~SATBBufferClosure() { }
|
|
|
|
|
|
|
|
public:
|
|
|
|
// Process the SATB entries in the designated buffer range.
|
|
|
|
virtual void do_buffer(void** buffer, size_t size) = 0;
|
|
|
|
};
|
|
|
|
|
2015-11-06 16:30:40 -05:00
|
|
|
// A PtrQueue whose elements are (possibly stale) pointers to object heads.
|
|
|
|
class SATBMarkQueue: public PtrQueue {
|
2012-01-10 18:58:13 -05:00
|
|
|
friend class SATBMarkQueueSet;
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Filter out unwanted entries from the buffer.
|
|
|
|
void filter();
|
|
|
|
|
2008-06-05 15:57:56 -07:00
|
|
|
public:
|
2015-11-06 16:30:40 -05:00
|
|
|
SATBMarkQueue(SATBMarkQueueSet* qset, bool permanent = false);
|
2011-01-19 09:35:17 -05:00
|
|
|
|
2014-07-31 11:10:02 +02:00
|
|
|
// Process queue entries and free resources.
|
|
|
|
void flush();
|
2012-01-10 18:58:13 -05:00
|
|
|
|
2015-05-01 17:38:12 -04:00
|
|
|
// Apply cl to the active part of the buffer.
|
|
|
|
// Prerequisite: Must be at a safepoint.
|
|
|
|
void apply_closure_and_empty(SATBBufferClosure* cl);
|
|
|
|
|
2011-01-19 09:35:17 -05:00
|
|
|
// Overrides PtrQueue::should_enqueue_buffer(). See the method's
|
|
|
|
// definition for more information.
|
|
|
|
virtual bool should_enqueue_buffer();
|
|
|
|
|
2012-01-10 18:58:13 -05:00
|
|
|
#ifndef PRODUCT
|
|
|
|
// Helpful for debugging
|
|
|
|
void print(const char* name);
|
|
|
|
static void print(const char* name, void** buf, size_t index, size_t sz);
|
|
|
|
#endif // PRODUCT
|
2008-06-05 15:57:56 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
class SATBMarkQueueSet: public PtrQueueSet {
|
2015-11-06 16:30:40 -05:00
|
|
|
SATBMarkQueue _shared_satb_queue;
|
2008-06-05 15:57:56 -07:00
|
|
|
|
2010-03-18 12:14:59 -04:00
|
|
|
#ifdef ASSERT
|
2014-01-10 09:54:25 +01:00
|
|
|
void dump_active_states(bool expected_active);
|
|
|
|
void verify_active_states(bool expected_active);
|
2010-03-18 12:14:59 -04:00
|
|
|
#endif // ASSERT
|
2008-06-05 15:57:56 -07:00
|
|
|
|
|
|
|
public:
|
|
|
|
SATBMarkQueueSet();
|
|
|
|
|
|
|
|
void initialize(Monitor* cbl_mon, Mutex* fl_lock,
|
2009-12-16 15:12:51 -08:00
|
|
|
int process_completed_threshold,
|
|
|
|
Mutex* lock);
|
2008-06-05 15:57:56 -07:00
|
|
|
|
|
|
|
static void handle_zero_index_for_thread(JavaThread* t);
|
|
|
|
|
2014-01-10 09:54:25 +01:00
|
|
|
// Apply "set_active(active)" to all SATB queues in the set. It should be
|
2010-03-18 12:14:59 -04:00
|
|
|
// called only with the world stopped. The method will assert that the
|
|
|
|
// SATB queues of all threads it visits, as well as the SATB queue
|
|
|
|
// set itself, has an active value same as expected_active.
|
2014-01-10 09:54:25 +01:00
|
|
|
void set_active_all_threads(bool active, bool expected_active);
|
2008-06-05 15:57:56 -07:00
|
|
|
|
2012-01-10 18:58:13 -05:00
|
|
|
// Filter all the currently-active SATB buffers.
|
|
|
|
void filter_thread_buffers();
|
|
|
|
|
2015-05-01 17:38:12 -04:00
|
|
|
// If there exists some completed buffer, pop and process it, and
|
|
|
|
// return true. Otherwise return false. Processing a buffer
|
|
|
|
// consists of applying the closure to the buffer range starting
|
|
|
|
// with the first non-NULL entry to the end of the buffer; the
|
|
|
|
// leading entries may be NULL due to filtering.
|
|
|
|
bool apply_closure_to_completed_buffer(SATBBufferClosure* cl);
|
2008-06-05 15:57:56 -07:00
|
|
|
|
2012-01-10 18:58:13 -05:00
|
|
|
#ifndef PRODUCT
|
|
|
|
// Helpful for debugging
|
|
|
|
void print_all(const char* msg);
|
|
|
|
#endif // PRODUCT
|
|
|
|
|
2015-11-06 16:30:40 -05:00
|
|
|
SATBMarkQueue* shared_satb_queue() { return &_shared_satb_queue; }
|
2008-06-05 15:57:56 -07:00
|
|
|
|
|
|
|
// If a marking is being abandoned, reset any unprocessed log buffers.
|
|
|
|
void abandon_partial_marking();
|
|
|
|
};
|
2010-11-23 13:22:55 -08:00
|
|
|
|
2015-11-06 16:30:40 -05:00
|
|
|
#endif // SHARE_VM_GC_G1_SATBMARKQUEUE_HPP
|