xref: /aosp_15_r20/art/openjdkjvmti/ti_class_loader.h (revision 795d594fd825385562da6b089ea9b2033f3abf5a)
1*795d594fSAndroid Build Coastguard Worker /* Copyright (C) 2017 The Android Open Source Project
2*795d594fSAndroid Build Coastguard Worker  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3*795d594fSAndroid Build Coastguard Worker  *
4*795d594fSAndroid Build Coastguard Worker  * This file implements interfaces from the file jvmti.h. This implementation
5*795d594fSAndroid Build Coastguard Worker  * is licensed under the same terms as the file jvmti.h.  The
6*795d594fSAndroid Build Coastguard Worker  * copyright and license information for the file jvmti.h follows.
7*795d594fSAndroid Build Coastguard Worker  *
8*795d594fSAndroid Build Coastguard Worker  * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
9*795d594fSAndroid Build Coastguard Worker  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
10*795d594fSAndroid Build Coastguard Worker  *
11*795d594fSAndroid Build Coastguard Worker  * This code is free software; you can redistribute it and/or modify it
12*795d594fSAndroid Build Coastguard Worker  * under the terms of the GNU General Public License version 2 only, as
13*795d594fSAndroid Build Coastguard Worker  * published by the Free Software Foundation.  Oracle designates this
14*795d594fSAndroid Build Coastguard Worker  * particular file as subject to the "Classpath" exception as provided
15*795d594fSAndroid Build Coastguard Worker  * by Oracle in the LICENSE file that accompanied this code.
16*795d594fSAndroid Build Coastguard Worker  *
17*795d594fSAndroid Build Coastguard Worker  * This code is distributed in the hope that it will be useful, but WITHOUT
18*795d594fSAndroid Build Coastguard Worker  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
19*795d594fSAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
20*795d594fSAndroid Build Coastguard Worker  * version 2 for more details (a copy is included in the LICENSE file that
21*795d594fSAndroid Build Coastguard Worker  * accompanied this code).
22*795d594fSAndroid Build Coastguard Worker  *
23*795d594fSAndroid Build Coastguard Worker  * You should have received a copy of the GNU General Public License version
24*795d594fSAndroid Build Coastguard Worker  * 2 along with this work; if not, write to the Free Software Foundation,
25*795d594fSAndroid Build Coastguard Worker  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
26*795d594fSAndroid Build Coastguard Worker  *
27*795d594fSAndroid Build Coastguard Worker  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
28*795d594fSAndroid Build Coastguard Worker  * or visit www.oracle.com if you need additional information or have any
29*795d594fSAndroid Build Coastguard Worker  * questions.
30*795d594fSAndroid Build Coastguard Worker  */
31*795d594fSAndroid Build Coastguard Worker 
32*795d594fSAndroid Build Coastguard Worker #ifndef ART_OPENJDKJVMTI_TI_CLASS_LOADER_H_
33*795d594fSAndroid Build Coastguard Worker #define ART_OPENJDKJVMTI_TI_CLASS_LOADER_H_
34*795d594fSAndroid Build Coastguard Worker 
35*795d594fSAndroid Build Coastguard Worker #include <string>
36*795d594fSAndroid Build Coastguard Worker 
37*795d594fSAndroid Build Coastguard Worker #include <jni.h>
38*795d594fSAndroid Build Coastguard Worker 
39*795d594fSAndroid Build Coastguard Worker #include "base/globals.h"
40*795d594fSAndroid Build Coastguard Worker #include "base/mutex.h"
41*795d594fSAndroid Build Coastguard Worker #include "jvmti.h"
42*795d594fSAndroid Build Coastguard Worker #include "mirror/array.h"
43*795d594fSAndroid Build Coastguard Worker 
44*795d594fSAndroid Build Coastguard Worker namespace art {
45*795d594fSAndroid Build Coastguard Worker 
46*795d594fSAndroid Build Coastguard Worker class DexFile;
47*795d594fSAndroid Build Coastguard Worker template <class MirrorType> class Handle;
48*795d594fSAndroid Build Coastguard Worker template <class MirrorType> class ObjPtr;
49*795d594fSAndroid Build Coastguard Worker class Thread;
50*795d594fSAndroid Build Coastguard Worker 
51*795d594fSAndroid Build Coastguard Worker }  // namespace art
52*795d594fSAndroid Build Coastguard Worker 
53*795d594fSAndroid Build Coastguard Worker namespace openjdkjvmti {
54*795d594fSAndroid Build Coastguard Worker 
55*795d594fSAndroid Build Coastguard Worker // Class that can redefine a single class's methods.
56*795d594fSAndroid Build Coastguard Worker // TODO We should really make this be driven by an outside class so we can do multiple classes at
57*795d594fSAndroid Build Coastguard Worker // the same time and have less required cleanup.
58*795d594fSAndroid Build Coastguard Worker class ClassLoaderHelper {
59*795d594fSAndroid Build Coastguard Worker  public:
60*795d594fSAndroid Build Coastguard Worker   static bool AddToClassLoader(art::Thread* self,
61*795d594fSAndroid Build Coastguard Worker                                art::Handle<art::mirror::ClassLoader> loader,
62*795d594fSAndroid Build Coastguard Worker                                const art::DexFile* dex_file)
63*795d594fSAndroid Build Coastguard Worker       REQUIRES_SHARED(art::Locks::mutator_lock_);
64*795d594fSAndroid Build Coastguard Worker 
65*795d594fSAndroid Build Coastguard Worker   // Finds a java.lang.DexFile object that is associated with the given ClassLoader. Each of these
66*795d594fSAndroid Build Coastguard Worker   // j.l.DexFile objects holds several art::DexFile*s in it.
67*795d594fSAndroid Build Coastguard Worker   // TODO This should return the actual source java.lang.DexFile object for the klass being loaded.
68*795d594fSAndroid Build Coastguard Worker   static art::ObjPtr<art::mirror::Object> FindSourceDexFileObject(
69*795d594fSAndroid Build Coastguard Worker       art::Thread* self, art::Handle<art::mirror::ClassLoader> loader)
70*795d594fSAndroid Build Coastguard Worker       REQUIRES_SHARED(art::Locks::mutator_lock_);
71*795d594fSAndroid Build Coastguard Worker 
72*795d594fSAndroid Build Coastguard Worker   // Calls visitor on each java.lang.DexFile associated with the given loader. The visitor should
73*795d594fSAndroid Build Coastguard Worker   // return true to continue on to the next DexFile or false to stop iterating.
74*795d594fSAndroid Build Coastguard Worker   template<typename Visitor>
75*795d594fSAndroid Build Coastguard Worker   static inline void VisitDexFileObjects(art::Thread* self,
76*795d594fSAndroid Build Coastguard Worker                                          art::Handle<art::mirror::ClassLoader> loader,
77*795d594fSAndroid Build Coastguard Worker                                          const Visitor& visitor)
78*795d594fSAndroid Build Coastguard Worker       REQUIRES_SHARED(art::Locks::mutator_lock_);
79*795d594fSAndroid Build Coastguard Worker 
80*795d594fSAndroid Build Coastguard Worker   static art::ObjPtr<art::mirror::LongArray> GetDexFileCookie(
81*795d594fSAndroid Build Coastguard Worker       art::Handle<art::mirror::Object> java_dex_file) REQUIRES_SHARED(art::Locks::mutator_lock_);
82*795d594fSAndroid Build Coastguard Worker 
83*795d594fSAndroid Build Coastguard Worker   static art::ObjPtr<art::mirror::LongArray> AllocateNewDexFileCookie(
84*795d594fSAndroid Build Coastguard Worker       art::Thread* self,
85*795d594fSAndroid Build Coastguard Worker       art::Handle<art::mirror::LongArray> old_dex_file_cookie,
86*795d594fSAndroid Build Coastguard Worker       const art::DexFile* new_dex_file) REQUIRES_SHARED(art::Locks::mutator_lock_);
87*795d594fSAndroid Build Coastguard Worker 
88*795d594fSAndroid Build Coastguard Worker   static void UpdateJavaDexFile(art::ObjPtr<art::mirror::Object> java_dex_file,
89*795d594fSAndroid Build Coastguard Worker                                 art::ObjPtr<art::mirror::LongArray> new_cookie)
90*795d594fSAndroid Build Coastguard Worker       REQUIRES(art::Roles::uninterruptible_) REQUIRES_SHARED(art::Locks::mutator_lock_);
91*795d594fSAndroid Build Coastguard Worker 
92*795d594fSAndroid Build Coastguard Worker  private:
93*795d594fSAndroid Build Coastguard Worker   static art::ObjPtr<art::mirror::ObjectArray<art::mirror::Object>> GetDexElementList(
94*795d594fSAndroid Build Coastguard Worker       art::Thread* self, art::Handle<art::mirror::ClassLoader> loader)
95*795d594fSAndroid Build Coastguard Worker         REQUIRES_SHARED(art::Locks::mutator_lock_);
96*795d594fSAndroid Build Coastguard Worker };
97*795d594fSAndroid Build Coastguard Worker 
98*795d594fSAndroid Build Coastguard Worker }  // namespace openjdkjvmti
99*795d594fSAndroid Build Coastguard Worker #endif  // ART_OPENJDKJVMTI_TI_CLASS_LOADER_H_
100