Path: blob/aarch64-shenandoah-jdk8u272-b10/hotspot/src/share/vm/oops/instanceClassLoaderKlass.cpp
32285 views
/*1* Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*22*/2324#include "precompiled.hpp"25#include "classfile/javaClasses.hpp"26#include "classfile/systemDictionary.hpp"27#include "gc_implementation/shared/markSweep.inline.hpp"28#include "gc_interface/collectedHeap.inline.hpp"29#include "memory/genOopClosures.inline.hpp"30#include "memory/iterator.inline.hpp"31#include "memory/oopFactory.hpp"32#include "oops/instanceKlass.hpp"33#include "oops/instanceClassLoaderKlass.hpp"34#include "oops/instanceMirrorKlass.hpp"35#include "oops/instanceOop.hpp"36#include "oops/oop.inline.hpp"37#include "oops/symbol.hpp"38#include "runtime/handles.inline.hpp"39#include "utilities/macros.hpp"40#if INCLUDE_ALL_GCS41#include "gc_implementation/parNew/parOopClosures.inline.hpp"42#include "gc_implementation/parallelScavenge/psPromotionManager.inline.hpp"43#include "gc_implementation/parallelScavenge/psScavenge.inline.hpp"44#include "oops/oop.pcgc.inline.hpp"45#endif // INCLUDE_ALL_GCS4647// Macro to define InstanceClassLoaderKlass::oop_oop_iterate for virtual/nonvirtual for48// all closures. Macros calling macros above for each oop size.49// Since ClassLoader objects have only a pointer to the loader_data, they are not50// compressed nor does the pointer move.5152#define InstanceClassLoaderKlass_OOP_OOP_ITERATE_DEFN(OopClosureType, nv_suffix)\53\54int InstanceClassLoaderKlass:: \55oop_oop_iterate##nv_suffix(oop obj, OopClosureType* closure) { \56/* Get size before changing pointers */ \57SpecializationStats::record_iterate_call##nv_suffix(SpecializationStats::irk);\58int size = InstanceKlass::oop_oop_iterate##nv_suffix(obj, closure); \59\60if_do_metadata_checked(closure, nv_suffix) { \61ClassLoaderData* cld = java_lang_ClassLoader::loader_data(obj); \62/* cld can be null if we have a non-registered class loader. */ \63if (cld != NULL) { \64closure->do_class_loader_data(cld); \65} \66} \67\68return size; \69}7071#if INCLUDE_ALL_GCS72#define InstanceClassLoaderKlass_OOP_OOP_ITERATE_BACKWARDS_DEFN(OopClosureType, nv_suffix) \73\74int InstanceClassLoaderKlass:: \75oop_oop_iterate_backwards##nv_suffix(oop obj, OopClosureType* closure) { \76/* Get size before changing pointers */ \77SpecializationStats::record_iterate_call##nv_suffix(SpecializationStats::irk);\78int size = InstanceKlass::oop_oop_iterate_backwards##nv_suffix(obj, closure); \79return size; \80}81#endif // INCLUDE_ALL_GCS828384#define InstanceClassLoaderKlass_OOP_OOP_ITERATE_DEFN_m(OopClosureType, nv_suffix) \85\86int InstanceClassLoaderKlass:: \87oop_oop_iterate##nv_suffix##_m(oop obj, \88OopClosureType* closure, \89MemRegion mr) { \90SpecializationStats::record_iterate_call##nv_suffix(SpecializationStats::irk);\91\92int size = InstanceKlass::oop_oop_iterate##nv_suffix##_m(obj, closure, mr); \93\94if_do_metadata_checked(closure, nv_suffix) { \95if (mr.contains(obj)) { \96ClassLoaderData* cld = java_lang_ClassLoader::loader_data(obj); \97/* cld can be null if we have a non-registered class loader. */ \98if (cld != NULL) { \99closure->do_class_loader_data(cld); \100} \101} \102} \103\104return size; \105}106107ALL_OOP_OOP_ITERATE_CLOSURES_1(InstanceClassLoaderKlass_OOP_OOP_ITERATE_DEFN)108ALL_OOP_OOP_ITERATE_CLOSURES_2(InstanceClassLoaderKlass_OOP_OOP_ITERATE_DEFN)109#if INCLUDE_ALL_GCS110ALL_OOP_OOP_ITERATE_CLOSURES_1(InstanceClassLoaderKlass_OOP_OOP_ITERATE_BACKWARDS_DEFN)111ALL_OOP_OOP_ITERATE_CLOSURES_2(InstanceClassLoaderKlass_OOP_OOP_ITERATE_BACKWARDS_DEFN)112#endif // INCLUDE_ALL_GCS113ALL_OOP_OOP_ITERATE_CLOSURES_1(InstanceClassLoaderKlass_OOP_OOP_ITERATE_DEFN_m)114ALL_OOP_OOP_ITERATE_CLOSURES_2(InstanceClassLoaderKlass_OOP_OOP_ITERATE_DEFN_m)115116void InstanceClassLoaderKlass::oop_follow_contents(oop obj) {117InstanceKlass::oop_follow_contents(obj);118ClassLoaderData * const loader_data = java_lang_ClassLoader::loader_data(obj);119120// We must NULL check here, since the class loader121// can be found before the loader data has been set up.122if(loader_data != NULL) {123MarkSweep::follow_class_loader(loader_data);124}125}126127#if INCLUDE_ALL_GCS128void InstanceClassLoaderKlass::oop_follow_contents(ParCompactionManager* cm,129oop obj) {130InstanceKlass::oop_follow_contents(cm, obj);131ClassLoaderData * const loader_data = java_lang_ClassLoader::loader_data(obj);132if (loader_data != NULL) {133PSParallelCompact::follow_class_loader(cm, loader_data);134}135}136137void InstanceClassLoaderKlass::oop_push_contents(PSPromotionManager* pm, oop obj) {138InstanceKlass::oop_push_contents(pm, obj);139140// This is called by the young collector. It will already have taken care of141// all class loader data. So, we don't have to follow the class loader ->142// class loader data link.143}144145int InstanceClassLoaderKlass::oop_update_pointers(ParCompactionManager* cm, oop obj) {146InstanceKlass::oop_update_pointers(cm, obj);147return size_helper();148}149#endif // INCLUDE_ALL_GCS150151152153