Path: blob/master/runtime/gc_check/FixDeadObjects.cpp
5985 views
/*******************************************************************************1* Copyright (c) 1991, 2017 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 "j9cfg.h"2324#include "CheckEngine.hpp"25#include "FixDeadObjects.hpp"26#include "HeapIteratorAPI.h"27#include "ModronTypes.hpp"28#include "ScanFormatter.hpp"2930/**31* Private struct used as the user data for the iterator callbacks. The regionDesc will get set32* by the region iterator callback.33*/34typedef struct FixDeadObjectsIteratorCallbackUserData {35GC_CheckEngine* engine; /* Input */36J9PortLibrary* portLibrary; /* Input */37J9MM_IterateRegionDescriptor* regionDesc; /* Temp - used internally by iterator functions */38} FixDeadObjectsIteratorCallbackUserData;3940/**41* Iterator callbacks, these are chained to eventually get to objects and their regions.42*/43static jvmtiIterationControl fix_heapIteratorCallback(J9JavaVM* vm, J9MM_IterateHeapDescriptor* heapDesc, void* userData);44static jvmtiIterationControl fix_spaceIteratorCallback(J9JavaVM* vm, J9MM_IterateSpaceDescriptor* spaceDesc, void* userData);45static jvmtiIterationControl fix_regionIteratorCallback(J9JavaVM* vm, J9MM_IterateRegionDescriptor* regionDesc, void* userData);46static jvmtiIterationControl fix_objectIteratorCallback(J9JavaVM* vm, J9MM_IterateObjectDescriptor* objectDesc, void* userData);474849GC_Check *50GC_FixDeadObjects::newInstance(J9JavaVM *javaVM, GC_CheckEngine *engine)51{52MM_Forge *forge = MM_GCExtensions::getExtensions(javaVM)->getForge();5354GC_FixDeadObjects *check = (GC_FixDeadObjects *) forge->allocate(sizeof(GC_FixDeadObjects), MM_AllocationCategory::DIAGNOSTIC, J9_GET_CALLSITE());55if(check) {56new(check) GC_FixDeadObjects(javaVM, engine);57}58return check;59}6061void62GC_FixDeadObjects::kill()63{64MM_Forge *forge = MM_GCExtensions::getExtensions(_javaVM)->getForge();65forge->free(this);66}6768void69GC_FixDeadObjects::check()70{71/* Check by using the HeapIteratorAPI */72FixDeadObjectsIteratorCallbackUserData userData;73userData.engine = _engine;74userData.portLibrary = _portLibrary;75_javaVM->memoryManagerFunctions->j9mm_iterate_heaps(_javaVM, _portLibrary, 0, fix_heapIteratorCallback, &userData);76}7778void79GC_FixDeadObjects::print()80{81}8283static jvmtiIterationControl84fix_heapIteratorCallback(J9JavaVM* vm, J9MM_IterateHeapDescriptor* heapDesc, void* userData)85{86FixDeadObjectsIteratorCallbackUserData* castUserData = (FixDeadObjectsIteratorCallbackUserData*)userData;87vm->memoryManagerFunctions->j9mm_iterate_spaces(vm, castUserData->portLibrary, heapDesc, 0, fix_spaceIteratorCallback, castUserData);88return JVMTI_ITERATION_CONTINUE;89}9091static jvmtiIterationControl92fix_spaceIteratorCallback(J9JavaVM* vm, J9MM_IterateSpaceDescriptor* spaceDesc, void* userData)93{94FixDeadObjectsIteratorCallbackUserData* castUserData = (FixDeadObjectsIteratorCallbackUserData*)userData;95vm->memoryManagerFunctions->j9mm_iterate_regions(vm, castUserData->portLibrary, spaceDesc, 0, fix_regionIteratorCallback, castUserData);96return JVMTI_ITERATION_CONTINUE;97}9899static jvmtiIterationControl100fix_regionIteratorCallback(J9JavaVM* vm, J9MM_IterateRegionDescriptor* regionDesc, void* userData)101{102FixDeadObjectsIteratorCallbackUserData* castUserData = (FixDeadObjectsIteratorCallbackUserData*)userData;103castUserData->regionDesc = regionDesc;104vm->memoryManagerFunctions->j9mm_iterate_region_objects(vm, castUserData->portLibrary, regionDesc, 0, fix_objectIteratorCallback, castUserData);105return JVMTI_ITERATION_CONTINUE;106}107108static jvmtiIterationControl109fix_objectIteratorCallback(J9JavaVM* vm, J9MM_IterateObjectDescriptor* objectDesc, void* userData)110{111FixDeadObjectsIteratorCallbackUserData* castUserData = (FixDeadObjectsIteratorCallbackUserData*)userData;112113/* Check the mark state of each object. If it isn't marked, build a dead object. */114if( !vm->memoryManagerFunctions->j9gc_ext_is_marked(vm, objectDesc->object) ) {115vm->memoryManagerFunctions->j9mm_abandon_object(vm, castUserData->regionDesc, objectDesc);116} else if (castUserData->engine->checkObjectHeap(vm, objectDesc, castUserData->regionDesc) != J9MODRON_SLOT_ITERATOR_OK) {117return JVMTI_ITERATION_ABORT;118}119120castUserData->engine->pushPreviousObject(objectDesc->object);121return JVMTI_ITERATION_CONTINUE;122}123124125