Path: blob/master/runtime/gc_check/CheckObjectHeap.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 "CheckEngine.hpp"23#include "CheckObjectHeap.hpp"24#include "MemorySubSpace.hpp"25#include "ModronTypes.hpp"26#include "ScanFormatter.hpp"27#include "HeapIteratorAPI.h"2829/**30* Private struct used as the user data for the iterator callbacks. The regionDesc will get set31* by the region iterator callback.32*/33typedef struct ObjectIteratorCallbackUserData {34GC_CheckEngine* engine; /* Input */35J9PortLibrary* portLibrary; /* Input */36J9MM_IterateRegionDescriptor* regionDesc; /* Temp - used internally by iterator functions */37} ObjectIteratorCallbackUserData;3839/**40* Iterator callbacks, these are chained to eventually get to objects and their regions.41*/42static jvmtiIterationControl check_heapIteratorCallback(J9JavaVM* vm, J9MM_IterateHeapDescriptor* heapDesc, void* userData);43static jvmtiIterationControl check_spaceIteratorCallback(J9JavaVM* vm, J9MM_IterateSpaceDescriptor* spaceDesc, void* userData);44static jvmtiIterationControl check_regionIteratorCallback(J9JavaVM* vm, J9MM_IterateRegionDescriptor* regionDesc, void* userData);45static jvmtiIterationControl check_objectIteratorCallback(J9JavaVM* vm, J9MM_IterateObjectDescriptor* objectDesc, void* userData);4647GC_Check *48GC_CheckObjectHeap::newInstance(J9JavaVM *javaVM, GC_CheckEngine *engine)49{50MM_Forge *forge = MM_GCExtensions::getExtensions(javaVM)->getForge();5152GC_CheckObjectHeap *check = (GC_CheckObjectHeap *) forge->allocate(sizeof(GC_CheckObjectHeap), MM_AllocationCategory::DIAGNOSTIC, J9_GET_CALLSITE());53if(check) {54new(check) GC_CheckObjectHeap(javaVM, engine);55}56return check;57}5859void60GC_CheckObjectHeap::kill()61{62MM_Forge *forge = MM_GCExtensions::getExtensions(_javaVM)->getForge();63forge->free(this);64}6566void67GC_CheckObjectHeap::check()68{69/* Check by using the HeapIteratorAPI */70ObjectIteratorCallbackUserData userData;71userData.engine = _engine;72userData.portLibrary = _portLibrary;73userData.regionDesc = NULL;74_javaVM->memoryManagerFunctions->j9mm_iterate_heaps(_javaVM, _portLibrary, 0, check_heapIteratorCallback, &userData);75}7677void78GC_CheckObjectHeap::print()79{80PORT_ACCESS_FROM_PORT(_portLibrary);81j9tty_printf(PORTLIB, "Printing of the object heap is supported through -Xtgc:terse\n");82}8384static jvmtiIterationControl85check_heapIteratorCallback(J9JavaVM* vm, J9MM_IterateHeapDescriptor* heapDesc, void* userData)86{87ObjectIteratorCallbackUserData* castUserData = (ObjectIteratorCallbackUserData*)userData;88vm->memoryManagerFunctions->j9mm_iterate_spaces(vm, castUserData->portLibrary, heapDesc, 0, check_spaceIteratorCallback, castUserData);89return JVMTI_ITERATION_CONTINUE;90}9192static jvmtiIterationControl93check_spaceIteratorCallback(J9JavaVM* vm, J9MM_IterateSpaceDescriptor* spaceDesc, void* userData)94{95ObjectIteratorCallbackUserData* castUserData = (ObjectIteratorCallbackUserData*)userData;96vm->memoryManagerFunctions->j9mm_iterate_regions(vm, castUserData->portLibrary, spaceDesc, 0, check_regionIteratorCallback, castUserData);97return JVMTI_ITERATION_CONTINUE;98}99100static jvmtiIterationControl101check_regionIteratorCallback(J9JavaVM* vm, J9MM_IterateRegionDescriptor* regionDesc, void* userData)102{103ObjectIteratorCallbackUserData* castUserData = (ObjectIteratorCallbackUserData*)userData;104castUserData->regionDesc = regionDesc;105vm->memoryManagerFunctions->j9mm_iterate_region_objects(vm, castUserData->portLibrary, regionDesc, j9mm_iterator_flag_include_holes, check_objectIteratorCallback, castUserData);106return JVMTI_ITERATION_CONTINUE;107}108109static jvmtiIterationControl110check_objectIteratorCallback(J9JavaVM* vm, J9MM_IterateObjectDescriptor* objectDesc, void* userData)111{112ObjectIteratorCallbackUserData* castUserData = (ObjectIteratorCallbackUserData*)userData;113if (castUserData->engine->checkObjectHeap(vm, objectDesc, castUserData->regionDesc) != J9MODRON_SLOT_ITERATOR_OK) {114return JVMTI_ITERATION_ABORT;115}116117castUserData->engine->pushPreviousObject(objectDesc->object);118return JVMTI_ITERATION_CONTINUE;119}120121122