Path: blob/master/runtime/gc_base/OwnableSynchronizerObjectBuffer.hpp
5985 views
1/*******************************************************************************2* Copyright (c) 1991, 2014 IBM Corp. and others3*4* This program and the accompanying materials are made available under5* the terms of the Eclipse Public License 2.0 which accompanies this6* distribution and is available at https://www.eclipse.org/legal/epl-2.0/7* or the Apache License, Version 2.0 which accompanies this distribution and8* is available at https://www.apache.org/licenses/LICENSE-2.0.9*10* This Source Code may also be made available under the following11* Secondary Licenses when the conditions for such availability set12* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU13* General Public License, version 2 with the GNU Classpath14* Exception [1] and GNU General Public License, version 2 with the15* OpenJDK Assembly Exception [2].16*17* [1] https://www.gnu.org/software/classpath/license.html18* [2] http://openjdk.java.net/legal/assembly-exception.html19*20* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception21*******************************************************************************/2223#ifndef OWNABLESYNCHRONIZEROBJECTBUFFER_HPP_24#define OWNABLESYNCHRONIZEROBJECTBUFFER_HPP_2526#include "j9.h"27#include "j9cfg.h"2829#include "BaseVirtual.hpp"3031class MM_EnvironmentBase;32class MM_GCExtensions;33class MM_HeapRegionDescriptor;3435/**36* A per-thread buffer of recently allocated OwnableSynchronizer objects.37* The buffer is periodically flushed to the global list.38*/39class MM_OwnableSynchronizerObjectBuffer : public MM_BaseVirtual40{41private:42protected:43j9object_t _head; /**< the head of the linked list of OwnableSynchronizer objects */44j9object_t _tail; /**< the tail of the linked list of OwnableSynchronizer objects */45MM_HeapRegionDescriptor* _region; /**< the region in which all buffered objects are located */46UDATA _objectCount; /**< the number of buffered objects */47const UDATA _maxObjectCount; /**< the maximum number of objects permitted before a forced flush */48MM_GCExtensions * const _extensions; /**< a cached pointer to the extensions structure */49public:5051private:5253/**54* Reset a flushed buffer to the empty state.55*/56void reset();5758protected:5960virtual bool initialize(MM_EnvironmentBase *env) = 0;61virtual void tearDown(MM_EnvironmentBase *env) = 0;6263/**64* Flush the contents of the buffer to the appropriate global buffers.65* Subclasses must override.66* @param env[in] the current thread67*/68virtual void flushImpl(MM_EnvironmentBase* env);6970public:71void kill(MM_EnvironmentBase *env);72/**73* Add the specified OwnableSynchronizer object to the buffer.74* @param env[in] the current thread75* @param object[in] the object to add76*/77void add(MM_EnvironmentBase* env, j9object_t object);7879/**80* Flush the contents of the buffer to the appropriate global buffers.81* @param env[in] the current thread82*/83void flush(MM_EnvironmentBase* env);8485/**86* Construct a new buffer.87* @param extensions[in] the GC extensions88* @param maxObjectCount the maximum number of objects permitted before a forced flush89*/90MM_OwnableSynchronizerObjectBuffer(MM_GCExtensions *extensions, UDATA maxObjectCount);91};9293#endif /* OWNABLESYNCHRONIZEROBJECTBUFFER_HPP_ */949596