Path: blob/master/runtime/gc_check/CheckOwnableSynchronizerList.cpp
5990 views
/*******************************************************************************1* Copyright (c) 1991, 2019 IBM Corp. and others2*3* This program and the accompanying materials are made available under4* the terms of the Eclipse Public License 2.0 which accompanies this5* distribution and is available at https://www.eclipse.org/legal/epl-2.0/6* or the Apache License, Version 2.0 which accompanies this distribution and7* is available at https://www.apache.org/licenses/LICENSE-2.0.8*9* This Source Code may also be made available under the following10* Secondary Licenses when the conditions for such availability set11* forth in the Eclipse Public License, v. 2.0 are satisfied: GNU12* General Public License, version 2 with the GNU Classpath13* Exception [1] and GNU General Public License, version 2 with the14* OpenJDK Assembly Exception [2].15*16* [1] https://www.gnu.org/software/classpath/license.html17* [2] http://openjdk.java.net/legal/assembly-exception.html18*19* 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-exception20*******************************************************************************/2122#include "CheckEngine.hpp"23#include "CheckOwnableSynchronizerList.hpp"24#include "ModronTypes.hpp"25#include "ObjectAccessBarrier.hpp"26#include "ScanFormatter.hpp"27#include "OwnableSynchronizerObjectList.hpp"28#include "HeapRegionManager.hpp"2930GC_Check *31GC_CheckOwnableSynchronizerList::newInstance(J9JavaVM *javaVM, GC_CheckEngine *engine)32{33MM_Forge *forge = MM_GCExtensions::getExtensions(javaVM)->getForge();3435GC_CheckOwnableSynchronizerList *check = (GC_CheckOwnableSynchronizerList *) forge->allocate(sizeof(GC_CheckOwnableSynchronizerList), MM_AllocationCategory::DIAGNOSTIC, J9_GET_CALLSITE());36if(NULL != check) {37new(check) GC_CheckOwnableSynchronizerList(javaVM, engine);38}39return check;40}4142void43GC_CheckOwnableSynchronizerList::kill()44{45MM_Forge *forge = MM_GCExtensions::getExtensions(_javaVM)->getForge();46forge->free(this);47}4849void50GC_CheckOwnableSynchronizerList::check()51{52MM_ObjectAccessBarrier *barrier = _extensions->accessBarrier;53MM_OwnableSynchronizerObjectList *ownableSynchronizerObjectList = _extensions->getOwnableSynchronizerObjectLists();5455MM_HeapRegionManager* heapRegionManager = _extensions->heapRegionManager;56UDATA maximumOwnableSynchronizerCountOnHeap = heapRegionManager->getTotalHeapSizeInBytes()/J9_GC_MINIMUM_OBJECT_SIZE;57UDATA ownableSynchronizerCount = 0;5859while (NULL != ownableSynchronizerObjectList) {60J9Object *objectPtr = ownableSynchronizerObjectList->getHeadOfList();61while (NULL != objectPtr) {62if (J9MODRON_SLOT_ITERATOR_OK != _engine->checkSlotOwnableSynchronizerList(_javaVM, &objectPtr, ownableSynchronizerObjectList)) {63return;64}65objectPtr = barrier->getOwnableSynchronizerLink(objectPtr);66ownableSynchronizerCount += 1;67if (ownableSynchronizerCount > maximumOwnableSynchronizerCountOnHeap) {68PORT_ACCESS_FROM_PORT(_portLibrary);69j9tty_printf(PORTLIB, " <gc check: found that circular reference in the OwnableSynchronizerList=%p, maximum OwnableSynchronizerCount =%zu >\n", ownableSynchronizerObjectList, maximumOwnableSynchronizerCountOnHeap);70return;71}72}73ownableSynchronizerObjectList = ownableSynchronizerObjectList->getNextList();74}75/* call verifyOwnableSynchronizerObjectCounts() only at the end of CheckOwnableSynchronizerList,76* verifyOwnableSynchronizerObjectCounts need both the count calculated in CheckObjectHeap and in CheckOwnableSynchronizerList77* assumption: CheckOwnableSynchronizerList always happens after CheckObjectHeap in CheckCycle78*/79_engine->verifyOwnableSynchronizerObjectCounts();80}8182void83GC_CheckOwnableSynchronizerList::print()84{85MM_ObjectAccessBarrier *barrier = _extensions->accessBarrier;86MM_OwnableSynchronizerObjectList *ownableSynchronizerObjectList = _extensions->getOwnableSynchronizerObjectLists();8788GC_ScanFormatter formatter(_portLibrary, "ownableSynchronizerObjectList");89while(NULL != ownableSynchronizerObjectList) {90formatter.section("list", (void *) ownableSynchronizerObjectList);91J9Object *objectPtr = ownableSynchronizerObjectList->getHeadOfList();92while (NULL != objectPtr) {93formatter.entry((void *) objectPtr);94objectPtr = barrier->getOwnableSynchronizerLink(objectPtr);95}96formatter.endSection();97ownableSynchronizerObjectList = ownableSynchronizerObjectList->getNextList();98}99formatter.end("ownableSynchronizerObjectList");100}101102103104