1 /* Copyright (C) 2016 The Android Open Source Project
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3 *
4 * This file implements interfaces from the file jvmti.h. This implementation
5 * is licensed under the same terms as the file jvmti.h. The
6 * copyright and license information for the file jvmti.h follows.
7 *
8 * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
9 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
10 *
11 * This code is free software; you can redistribute it and/or modify it
12 * under the terms of the GNU General Public License version 2 only, as
13 * published by the Free Software Foundation. Oracle designates this
14 * particular file as subject to the "Classpath" exception as provided
15 * by Oracle in the LICENSE file that accompanied this code.
16 *
17 * This code is distributed in the hope that it will be useful, but WITHOUT
18 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
19 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
20 * version 2 for more details (a copy is included in the LICENSE file that
21 * accompanied this code).
22 *
23 * You should have received a copy of the GNU General Public License version
24 * 2 along with this work; if not, write to the Free Software Foundation,
25 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
26 *
27 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
28 * or visit www.oracle.com if you need additional information or have any
29 * questions.
30 */
31
32 #include <memory>
33 #include <string>
34 #include <type_traits>
35 #include <vector>
36
37 #include <android-base/logging.h>
38
39 #include <jni.h>
40
41 #include "jvmti.h"
42
43 #include "alloc_manager.h"
44 #include "art_jvmti.h"
45 #include "base/logging.h" // For gLogVerbosity.
46 #include "base/mutex.h"
47 #include "events-inl.h"
48 #include "jni/jni_env_ext-inl.h"
49 #include "obj_ptr-inl.h"
50 #include "object_tagging.h"
51 #include "runtime.h"
52 #include "scoped_thread_state_change-inl.h"
53 #include "thread-current-inl.h"
54 #include "thread_list.h"
55 #include "ti_allocator.h"
56 #include "ti_breakpoint.h"
57 #include "ti_class.h"
58 #include "ti_dump.h"
59 #include "ti_extension.h"
60 #include "ti_field.h"
61 #include "ti_heap.h"
62 #include "ti_jni.h"
63 #include "ti_logging.h"
64 #include "ti_method.h"
65 #include "ti_monitor.h"
66 #include "ti_object.h"
67 #include "ti_phase.h"
68 #include "ti_properties.h"
69 #include "ti_redefine.h"
70 #include "ti_search.h"
71 #include "ti_stack.h"
72 #include "ti_thread.h"
73 #include "ti_threadgroup.h"
74 #include "ti_timers.h"
75 #include "transform.h"
76
77 namespace openjdkjvmti {
78
79 // NB These are heap allocated to avoid the static destructors being run if an agent calls exit(3).
80 // These should never be null.
81 EventHandler* gEventHandler;
82 DeoptManager* gDeoptManager;
83 AllocationManager* gAllocManager;
84
85 #define ENSURE_NON_NULL(n) \
86 do { \
87 if ((n) == nullptr) { \
88 return ERR(NULL_POINTER); \
89 } \
90 } while (false)
91
92 class JvmtiFunctions {
93 private:
getEnvironmentError(jvmtiEnv * env)94 static jvmtiError getEnvironmentError(jvmtiEnv* env) {
95 if (env == nullptr) {
96 return ERR(INVALID_ENVIRONMENT);
97 } else if (art::Thread::Current() == nullptr) {
98 return ERR(UNATTACHED_THREAD);
99 } else {
100 return OK;
101 }
102 }
103
104 #define ENSURE_VALID_ENV(env) \
105 do { \
106 jvmtiError ensure_valid_env_ ## __LINE__ = getEnvironmentError(env); \
107 if (ensure_valid_env_ ## __LINE__ != OK) { \
108 return ensure_valid_env_ ## __LINE__ ; \
109 } \
110 } while (false)
111
112 #define ENSURE_HAS_CAP(env, cap) \
113 do { \
114 if (ArtJvmTiEnv::AsArtJvmTiEnv(env)->capabilities.cap != 1) { \
115 return ERR(MUST_POSSESS_CAPABILITY); \
116 } \
117 } while (false)
118
119 public:
Allocate(jvmtiEnv * env,jlong size,unsigned char ** mem_ptr)120 static jvmtiError Allocate(jvmtiEnv* env, jlong size, unsigned char** mem_ptr) {
121 jvmtiError err = getEnvironmentError(env);
122 // Allow UNATTACHED_THREAD since we don't really care about that for this function.
123 if (err != OK && err != ERR(UNATTACHED_THREAD)) {
124 return err;
125 }
126 ENSURE_NON_NULL(mem_ptr);
127 return AllocUtil::Allocate(env, size, mem_ptr);
128 }
129
Deallocate(jvmtiEnv * env,unsigned char * mem)130 static jvmtiError Deallocate(jvmtiEnv* env, unsigned char* mem) {
131 jvmtiError err = getEnvironmentError(env);
132 // Allow UNATTACHED_THREAD since we don't really care about that for this function.
133 if (err != OK && err != ERR(UNATTACHED_THREAD)) {
134 return err;
135 }
136 return AllocUtil::Deallocate(env, mem);
137 }
138
GetThreadState(jvmtiEnv * env,jthread thread,jint * thread_state_ptr)139 static jvmtiError GetThreadState(jvmtiEnv* env, jthread thread, jint* thread_state_ptr) {
140 ENSURE_VALID_ENV(env);
141 return ThreadUtil::GetThreadState(env, thread, thread_state_ptr);
142 }
143
GetCurrentThread(jvmtiEnv * env,jthread * thread_ptr)144 static jvmtiError GetCurrentThread(jvmtiEnv* env, jthread* thread_ptr) {
145 ENSURE_VALID_ENV(env);
146 return ThreadUtil::GetCurrentThread(env, thread_ptr);
147 }
148
GetAllThreads(jvmtiEnv * env,jint * threads_count_ptr,jthread ** threads_ptr)149 static jvmtiError GetAllThreads(jvmtiEnv* env, jint* threads_count_ptr, jthread** threads_ptr) {
150 ENSURE_VALID_ENV(env);
151 return ThreadUtil::GetAllThreads(env, threads_count_ptr, threads_ptr);
152 }
153
SuspendThread(jvmtiEnv * env,jthread thread)154 static jvmtiError SuspendThread(jvmtiEnv* env, jthread thread) {
155 ENSURE_VALID_ENV(env);
156 ENSURE_HAS_CAP(env, can_suspend);
157 return ThreadUtil::SuspendThread(env, thread);
158 }
159
SuspendThreadList(jvmtiEnv * env,jint request_count,const jthread * request_list,jvmtiError * results)160 static jvmtiError SuspendThreadList(jvmtiEnv* env,
161 jint request_count,
162 const jthread* request_list,
163 jvmtiError* results) {
164 ENSURE_VALID_ENV(env);
165 ENSURE_HAS_CAP(env, can_suspend);
166 return ThreadUtil::SuspendThreadList(env, request_count, request_list, results);
167 }
168
ResumeThread(jvmtiEnv * env,jthread thread)169 static jvmtiError ResumeThread(jvmtiEnv* env, jthread thread) {
170 ENSURE_VALID_ENV(env);
171 ENSURE_HAS_CAP(env, can_suspend);
172 return ThreadUtil::ResumeThread(env, thread);
173 }
174
ResumeThreadList(jvmtiEnv * env,jint request_count,const jthread * request_list,jvmtiError * results)175 static jvmtiError ResumeThreadList(jvmtiEnv* env,
176 jint request_count,
177 const jthread* request_list,
178 jvmtiError* results) {
179 ENSURE_VALID_ENV(env);
180 ENSURE_HAS_CAP(env, can_suspend);
181 return ThreadUtil::ResumeThreadList(env, request_count, request_list, results);
182 }
183
StopThread(jvmtiEnv * env,jthread thread,jobject exception)184 static jvmtiError StopThread(jvmtiEnv* env, jthread thread, jobject exception) {
185 ENSURE_VALID_ENV(env);
186 ENSURE_HAS_CAP(env, can_signal_thread);
187 return ThreadUtil::StopThread(env, thread, exception);
188 }
189
InterruptThread(jvmtiEnv * env,jthread thread)190 static jvmtiError InterruptThread(jvmtiEnv* env, jthread thread) {
191 ENSURE_VALID_ENV(env);
192 ENSURE_HAS_CAP(env, can_signal_thread);
193 return ThreadUtil::InterruptThread(env, thread);
194 }
195
GetThreadInfo(jvmtiEnv * env,jthread thread,jvmtiThreadInfo * info_ptr)196 static jvmtiError GetThreadInfo(jvmtiEnv* env, jthread thread, jvmtiThreadInfo* info_ptr) {
197 ENSURE_VALID_ENV(env);
198 return ThreadUtil::GetThreadInfo(env, thread, info_ptr);
199 }
200
GetOwnedMonitorInfo(jvmtiEnv * env,jthread thread,jint * owned_monitor_count_ptr,jobject ** owned_monitors_ptr)201 static jvmtiError GetOwnedMonitorInfo(jvmtiEnv* env,
202 jthread thread,
203 jint* owned_monitor_count_ptr,
204 jobject** owned_monitors_ptr) {
205 ENSURE_VALID_ENV(env);
206 ENSURE_HAS_CAP(env, can_get_owned_monitor_info);
207 return StackUtil::GetOwnedMonitorInfo(env,
208 thread,
209 owned_monitor_count_ptr,
210 owned_monitors_ptr);
211 }
212
GetOwnedMonitorStackDepthInfo(jvmtiEnv * env,jthread thread,jint * monitor_info_count_ptr,jvmtiMonitorStackDepthInfo ** monitor_info_ptr)213 static jvmtiError GetOwnedMonitorStackDepthInfo(jvmtiEnv* env,
214 jthread thread,
215 jint* monitor_info_count_ptr,
216 jvmtiMonitorStackDepthInfo** monitor_info_ptr) {
217 ENSURE_VALID_ENV(env);
218 ENSURE_HAS_CAP(env, can_get_owned_monitor_stack_depth_info);
219 return StackUtil::GetOwnedMonitorStackDepthInfo(env,
220 thread,
221 monitor_info_count_ptr,
222 monitor_info_ptr);
223 }
224
GetCurrentContendedMonitor(jvmtiEnv * env,jthread thread,jobject * monitor_ptr)225 static jvmtiError GetCurrentContendedMonitor(jvmtiEnv* env,
226 jthread thread,
227 jobject* monitor_ptr) {
228 ENSURE_VALID_ENV(env);
229 ENSURE_HAS_CAP(env, can_get_current_contended_monitor);
230 return MonitorUtil::GetCurrentContendedMonitor(env, thread, monitor_ptr);
231 }
232
RunAgentThread(jvmtiEnv * env,jthread thread,jvmtiStartFunction proc,const void * arg,jint priority)233 static jvmtiError RunAgentThread(jvmtiEnv* env,
234 jthread thread,
235 jvmtiStartFunction proc,
236 const void* arg,
237 jint priority) {
238 ENSURE_VALID_ENV(env);
239 return ThreadUtil::RunAgentThread(env, thread, proc, arg, priority);
240 }
241
SetThreadLocalStorage(jvmtiEnv * env,jthread thread,const void * data)242 static jvmtiError SetThreadLocalStorage(jvmtiEnv* env, jthread thread, const void* data) {
243 ENSURE_VALID_ENV(env);
244 return ThreadUtil::SetThreadLocalStorage(env, thread, data);
245 }
246
GetThreadLocalStorage(jvmtiEnv * env,jthread thread,void ** data_ptr)247 static jvmtiError GetThreadLocalStorage(jvmtiEnv* env, jthread thread, void** data_ptr) {
248 ENSURE_VALID_ENV(env);
249 return ThreadUtil::GetThreadLocalStorage(env, thread, data_ptr);
250 }
251
GetTopThreadGroups(jvmtiEnv * env,jint * group_count_ptr,jthreadGroup ** groups_ptr)252 static jvmtiError GetTopThreadGroups(jvmtiEnv* env,
253 jint* group_count_ptr,
254 jthreadGroup** groups_ptr) {
255 ENSURE_VALID_ENV(env);
256 return ThreadGroupUtil::GetTopThreadGroups(env, group_count_ptr, groups_ptr);
257 }
258
GetThreadGroupInfo(jvmtiEnv * env,jthreadGroup group,jvmtiThreadGroupInfo * info_ptr)259 static jvmtiError GetThreadGroupInfo(jvmtiEnv* env,
260 jthreadGroup group,
261 jvmtiThreadGroupInfo* info_ptr) {
262 ENSURE_VALID_ENV(env);
263 return ThreadGroupUtil::GetThreadGroupInfo(env, group, info_ptr);
264 }
265
GetThreadGroupChildren(jvmtiEnv * env,jthreadGroup group,jint * thread_count_ptr,jthread ** threads_ptr,jint * group_count_ptr,jthreadGroup ** groups_ptr)266 static jvmtiError GetThreadGroupChildren(jvmtiEnv* env,
267 jthreadGroup group,
268 jint* thread_count_ptr,
269 jthread** threads_ptr,
270 jint* group_count_ptr,
271 jthreadGroup** groups_ptr) {
272 ENSURE_VALID_ENV(env);
273 return ThreadGroupUtil::GetThreadGroupChildren(env,
274 group,
275 thread_count_ptr,
276 threads_ptr,
277 group_count_ptr,
278 groups_ptr);
279 }
280
GetStackTrace(jvmtiEnv * env,jthread thread,jint start_depth,jint max_frame_count,jvmtiFrameInfo * frame_buffer,jint * count_ptr)281 static jvmtiError GetStackTrace(jvmtiEnv* env,
282 jthread thread,
283 jint start_depth,
284 jint max_frame_count,
285 jvmtiFrameInfo* frame_buffer,
286 jint* count_ptr) {
287 ENSURE_VALID_ENV(env);
288 return StackUtil::GetStackTrace(env,
289 thread,
290 start_depth,
291 max_frame_count,
292 frame_buffer,
293 count_ptr);
294 }
295
GetAllStackTraces(jvmtiEnv * env,jint max_frame_count,jvmtiStackInfo ** stack_info_ptr,jint * thread_count_ptr)296 static jvmtiError GetAllStackTraces(jvmtiEnv* env,
297 jint max_frame_count,
298 jvmtiStackInfo** stack_info_ptr,
299 jint* thread_count_ptr) {
300 ENSURE_VALID_ENV(env);
301 return StackUtil::GetAllStackTraces(env, max_frame_count, stack_info_ptr, thread_count_ptr);
302 }
303
GetThreadListStackTraces(jvmtiEnv * env,jint thread_count,const jthread * thread_list,jint max_frame_count,jvmtiStackInfo ** stack_info_ptr)304 static jvmtiError GetThreadListStackTraces(jvmtiEnv* env,
305 jint thread_count,
306 const jthread* thread_list,
307 jint max_frame_count,
308 jvmtiStackInfo** stack_info_ptr) {
309 ENSURE_VALID_ENV(env);
310 return StackUtil::GetThreadListStackTraces(env,
311 thread_count,
312 thread_list,
313 max_frame_count,
314 stack_info_ptr);
315 }
316
GetFrameCount(jvmtiEnv * env,jthread thread,jint * count_ptr)317 static jvmtiError GetFrameCount(jvmtiEnv* env, jthread thread, jint* count_ptr) {
318 ENSURE_VALID_ENV(env);
319 return StackUtil::GetFrameCount(env, thread, count_ptr);
320 }
321
PopFrame(jvmtiEnv * env,jthread thread)322 static jvmtiError PopFrame(jvmtiEnv* env, jthread thread) {
323 ENSURE_VALID_ENV(env);
324 ENSURE_HAS_CAP(env, can_pop_frame);
325 return StackUtil::PopFrame(env, thread);
326 }
327
GetFrameLocation(jvmtiEnv * env,jthread thread,jint depth,jmethodID * method_ptr,jlocation * location_ptr)328 static jvmtiError GetFrameLocation(jvmtiEnv* env,
329 jthread thread,
330 jint depth,
331 jmethodID* method_ptr,
332 jlocation* location_ptr) {
333 ENSURE_VALID_ENV(env);
334 return StackUtil::GetFrameLocation(env, thread, depth, method_ptr, location_ptr);
335 }
336
NotifyFramePop(jvmtiEnv * env,jthread thread,jint depth)337 static jvmtiError NotifyFramePop(jvmtiEnv* env, jthread thread, jint depth) {
338 ENSURE_VALID_ENV(env);
339 ENSURE_HAS_CAP(env, can_generate_frame_pop_events);
340 return StackUtil::NotifyFramePop(env, thread, depth);
341 }
342
ForceEarlyReturnObject(jvmtiEnv * env,jthread thread,jobject value)343 static jvmtiError ForceEarlyReturnObject(jvmtiEnv* env, jthread thread, jobject value) {
344 ENSURE_VALID_ENV(env);
345 ENSURE_HAS_CAP(env, can_force_early_return);
346 return StackUtil::ForceEarlyReturn(env, gEventHandler, thread, value);
347 }
348
ForceEarlyReturnInt(jvmtiEnv * env,jthread thread,jint value)349 static jvmtiError ForceEarlyReturnInt(jvmtiEnv* env, jthread thread, jint value) {
350 ENSURE_VALID_ENV(env);
351 ENSURE_HAS_CAP(env, can_force_early_return);
352 return StackUtil::ForceEarlyReturn(env, gEventHandler, thread, value);
353 }
354
ForceEarlyReturnLong(jvmtiEnv * env,jthread thread,jlong value)355 static jvmtiError ForceEarlyReturnLong(jvmtiEnv* env, jthread thread, jlong value) {
356 ENSURE_VALID_ENV(env);
357 ENSURE_HAS_CAP(env, can_force_early_return);
358 return StackUtil::ForceEarlyReturn(env, gEventHandler, thread, value);
359 }
360
ForceEarlyReturnFloat(jvmtiEnv * env,jthread thread,jfloat value)361 static jvmtiError ForceEarlyReturnFloat(jvmtiEnv* env, jthread thread, jfloat value) {
362 ENSURE_VALID_ENV(env);
363 ENSURE_HAS_CAP(env, can_force_early_return);
364 return StackUtil::ForceEarlyReturn(env, gEventHandler, thread, value);
365 }
366
ForceEarlyReturnDouble(jvmtiEnv * env,jthread thread,jdouble value)367 static jvmtiError ForceEarlyReturnDouble(jvmtiEnv* env, jthread thread, jdouble value) {
368 ENSURE_VALID_ENV(env);
369 ENSURE_HAS_CAP(env, can_force_early_return);
370 return StackUtil::ForceEarlyReturn(env, gEventHandler, thread, value);
371 }
372
ForceEarlyReturnVoid(jvmtiEnv * env,jthread thread)373 static jvmtiError ForceEarlyReturnVoid(jvmtiEnv* env, jthread thread) {
374 ENSURE_VALID_ENV(env);
375 ENSURE_HAS_CAP(env, can_force_early_return);
376 return StackUtil::ForceEarlyReturn<nullptr_t>(env, gEventHandler, thread, nullptr);
377 }
378
FollowReferences(jvmtiEnv * env,jint heap_filter,jclass klass,jobject initial_object,const jvmtiHeapCallbacks * callbacks,const void * user_data)379 static jvmtiError FollowReferences(jvmtiEnv* env,
380 jint heap_filter,
381 jclass klass,
382 jobject initial_object,
383 const jvmtiHeapCallbacks* callbacks,
384 const void* user_data) {
385 ENSURE_VALID_ENV(env);
386 ENSURE_HAS_CAP(env, can_tag_objects);
387 HeapUtil heap_util(ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table.get());
388 return heap_util.FollowReferences(env,
389 heap_filter,
390 klass,
391 initial_object,
392 callbacks,
393 user_data);
394 }
395
IterateThroughHeap(jvmtiEnv * env,jint heap_filter,jclass klass,const jvmtiHeapCallbacks * callbacks,const void * user_data)396 static jvmtiError IterateThroughHeap(jvmtiEnv* env,
397 jint heap_filter,
398 jclass klass,
399 const jvmtiHeapCallbacks* callbacks,
400 const void* user_data) {
401 ENSURE_VALID_ENV(env);
402 ENSURE_HAS_CAP(env, can_tag_objects);
403 HeapUtil heap_util(ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table.get());
404 return heap_util.IterateThroughHeap(env, heap_filter, klass, callbacks, user_data);
405 }
406
GetTag(jvmtiEnv * env,jobject object,jlong * tag_ptr)407 static jvmtiError GetTag(jvmtiEnv* env, jobject object, jlong* tag_ptr) {
408 ENSURE_VALID_ENV(env);
409 ENSURE_HAS_CAP(env, can_tag_objects);
410
411 JNIEnv* jni_env = GetJniEnv(env);
412 if (jni_env == nullptr) {
413 return ERR(INTERNAL);
414 }
415
416 art::ScopedObjectAccess soa(jni_env);
417 art::ObjPtr<art::mirror::Object> obj = soa.Decode<art::mirror::Object>(object);
418 if (!ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table->GetTag(obj.Ptr(), tag_ptr)) {
419 *tag_ptr = 0;
420 }
421
422 return ERR(NONE);
423 }
424
SetTag(jvmtiEnv * env,jobject object,jlong tag)425 static jvmtiError SetTag(jvmtiEnv* env, jobject object, jlong tag) {
426 ENSURE_VALID_ENV(env);
427 ENSURE_HAS_CAP(env, can_tag_objects);
428
429 if (object == nullptr) {
430 return ERR(NULL_POINTER);
431 }
432
433 JNIEnv* jni_env = GetJniEnv(env);
434 if (jni_env == nullptr) {
435 return ERR(INTERNAL);
436 }
437
438 art::ScopedObjectAccess soa(jni_env);
439 art::ObjPtr<art::mirror::Object> obj = soa.Decode<art::mirror::Object>(object);
440 ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table->Set(obj.Ptr(), tag);
441
442 return ERR(NONE);
443 }
444
GetObjectsWithTags(jvmtiEnv * env,jint tag_count,const jlong * tags,jint * count_ptr,jobject ** object_result_ptr,jlong ** tag_result_ptr)445 static jvmtiError GetObjectsWithTags(jvmtiEnv* env,
446 jint tag_count,
447 const jlong* tags,
448 jint* count_ptr,
449 jobject** object_result_ptr,
450 jlong** tag_result_ptr) {
451 ENSURE_VALID_ENV(env);
452 ENSURE_HAS_CAP(env, can_tag_objects);
453
454 JNIEnv* jni_env = GetJniEnv(env);
455 if (jni_env == nullptr) {
456 return ERR(INTERNAL);
457 }
458
459 art::ScopedObjectAccess soa(jni_env);
460 return ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table->GetTaggedObjects(env,
461 tag_count,
462 tags,
463 count_ptr,
464 object_result_ptr,
465 tag_result_ptr);
466 }
467
ForceGarbageCollection(jvmtiEnv * env)468 static jvmtiError ForceGarbageCollection(jvmtiEnv* env) {
469 ENSURE_VALID_ENV(env);
470 return HeapUtil::ForceGarbageCollection(env);
471 }
472
IterateOverObjectsReachableFromObject(jvmtiEnv * env,jobject object,jvmtiObjectReferenceCallback object_reference_callback,const void * user_data)473 static jvmtiError IterateOverObjectsReachableFromObject(
474 jvmtiEnv* env,
475 [[maybe_unused]] jobject object,
476 [[maybe_unused]] jvmtiObjectReferenceCallback object_reference_callback,
477 [[maybe_unused]] const void* user_data) {
478 ENSURE_VALID_ENV(env);
479 ENSURE_HAS_CAP(env, can_tag_objects);
480 return ERR(NOT_IMPLEMENTED);
481 }
482
IterateOverReachableObjects(jvmtiEnv * env,jvmtiHeapRootCallback heap_root_callback,jvmtiStackReferenceCallback stack_ref_callback,jvmtiObjectReferenceCallback object_ref_callback,const void * user_data)483 static jvmtiError IterateOverReachableObjects(
484 jvmtiEnv* env,
485 [[maybe_unused]] jvmtiHeapRootCallback heap_root_callback,
486 [[maybe_unused]] jvmtiStackReferenceCallback stack_ref_callback,
487 [[maybe_unused]] jvmtiObjectReferenceCallback object_ref_callback,
488 [[maybe_unused]] const void* user_data) {
489 ENSURE_VALID_ENV(env);
490 ENSURE_HAS_CAP(env, can_tag_objects);
491 return ERR(NOT_IMPLEMENTED);
492 }
493
IterateOverHeap(jvmtiEnv * env,jvmtiHeapObjectFilter object_filter,jvmtiHeapObjectCallback heap_object_callback,const void * user_data)494 static jvmtiError IterateOverHeap(jvmtiEnv* env,
495 [[maybe_unused]] jvmtiHeapObjectFilter object_filter,
496 [[maybe_unused]] jvmtiHeapObjectCallback heap_object_callback,
497 [[maybe_unused]] const void* user_data) {
498 ENSURE_VALID_ENV(env);
499 ENSURE_HAS_CAP(env, can_tag_objects);
500 return ERR(NOT_IMPLEMENTED);
501 }
502
IterateOverInstancesOfClass(jvmtiEnv * env,jclass klass,jvmtiHeapObjectFilter object_filter,jvmtiHeapObjectCallback heap_object_callback,const void * user_data)503 static jvmtiError IterateOverInstancesOfClass(
504 jvmtiEnv* env,
505 jclass klass,
506 jvmtiHeapObjectFilter object_filter,
507 jvmtiHeapObjectCallback heap_object_callback,
508 const void* user_data) {
509 ENSURE_VALID_ENV(env);
510 ENSURE_HAS_CAP(env, can_tag_objects);
511 HeapUtil heap_util(ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table.get());
512 return heap_util.IterateOverInstancesOfClass(
513 env, klass, object_filter, heap_object_callback, user_data);
514 }
515
GetLocalObject(jvmtiEnv * env,jthread thread,jint depth,jint slot,jobject * value_ptr)516 static jvmtiError GetLocalObject(jvmtiEnv* env,
517 jthread thread,
518 jint depth,
519 jint slot,
520 jobject* value_ptr) {
521 ENSURE_VALID_ENV(env);
522 ENSURE_HAS_CAP(env, can_access_local_variables);
523 return MethodUtil::GetLocalVariable(env, thread, depth, slot, value_ptr);
524 }
525
GetLocalInstance(jvmtiEnv * env,jthread thread,jint depth,jobject * value_ptr)526 static jvmtiError GetLocalInstance(jvmtiEnv* env,
527 jthread thread,
528 jint depth,
529 jobject* value_ptr) {
530 ENSURE_VALID_ENV(env);
531 ENSURE_HAS_CAP(env, can_access_local_variables);
532 return MethodUtil::GetLocalInstance(env, thread, depth, value_ptr);
533 }
534
GetLocalInt(jvmtiEnv * env,jthread thread,jint depth,jint slot,jint * value_ptr)535 static jvmtiError GetLocalInt(jvmtiEnv* env,
536 jthread thread,
537 jint depth,
538 jint slot,
539 jint* value_ptr) {
540 ENSURE_VALID_ENV(env);
541 ENSURE_HAS_CAP(env, can_access_local_variables);
542 return MethodUtil::GetLocalVariable(env, thread, depth, slot, value_ptr);
543 }
544
GetLocalLong(jvmtiEnv * env,jthread thread,jint depth,jint slot,jlong * value_ptr)545 static jvmtiError GetLocalLong(jvmtiEnv* env,
546 jthread thread,
547 jint depth,
548 jint slot,
549 jlong* value_ptr) {
550 ENSURE_VALID_ENV(env);
551 ENSURE_HAS_CAP(env, can_access_local_variables);
552 return MethodUtil::GetLocalVariable(env, thread, depth, slot, value_ptr);
553 }
554
GetLocalFloat(jvmtiEnv * env,jthread thread,jint depth,jint slot,jfloat * value_ptr)555 static jvmtiError GetLocalFloat(jvmtiEnv* env,
556 jthread thread,
557 jint depth,
558 jint slot,
559 jfloat* value_ptr) {
560 ENSURE_VALID_ENV(env);
561 ENSURE_HAS_CAP(env, can_access_local_variables);
562 return MethodUtil::GetLocalVariable(env, thread, depth, slot, value_ptr);
563 }
564
GetLocalDouble(jvmtiEnv * env,jthread thread,jint depth,jint slot,jdouble * value_ptr)565 static jvmtiError GetLocalDouble(jvmtiEnv* env,
566 jthread thread,
567 jint depth,
568 jint slot,
569 jdouble* value_ptr) {
570 ENSURE_VALID_ENV(env);
571 ENSURE_HAS_CAP(env, can_access_local_variables);
572 return MethodUtil::GetLocalVariable(env, thread, depth, slot, value_ptr);
573 }
574
SetLocalObject(jvmtiEnv * env,jthread thread,jint depth,jint slot,jobject value)575 static jvmtiError SetLocalObject(jvmtiEnv* env,
576 jthread thread,
577 jint depth,
578 jint slot,
579 jobject value) {
580 ENSURE_VALID_ENV(env);
581 ENSURE_HAS_CAP(env, can_access_local_variables);
582 return MethodUtil::SetLocalVariable(env, thread, depth, slot, value);
583 }
584
SetLocalInt(jvmtiEnv * env,jthread thread,jint depth,jint slot,jint value)585 static jvmtiError SetLocalInt(jvmtiEnv* env,
586 jthread thread,
587 jint depth,
588 jint slot,
589 jint value) {
590 ENSURE_VALID_ENV(env);
591 ENSURE_HAS_CAP(env, can_access_local_variables);
592 return MethodUtil::SetLocalVariable(env, thread, depth, slot, value);
593 }
594
SetLocalLong(jvmtiEnv * env,jthread thread,jint depth,jint slot,jlong value)595 static jvmtiError SetLocalLong(jvmtiEnv* env,
596 jthread thread,
597 jint depth,
598 jint slot,
599 jlong value) {
600 ENSURE_VALID_ENV(env);
601 ENSURE_HAS_CAP(env, can_access_local_variables);
602 return MethodUtil::SetLocalVariable(env, thread, depth, slot, value);
603 }
604
SetLocalFloat(jvmtiEnv * env,jthread thread,jint depth,jint slot,jfloat value)605 static jvmtiError SetLocalFloat(jvmtiEnv* env,
606 jthread thread,
607 jint depth,
608 jint slot,
609 jfloat value) {
610 ENSURE_VALID_ENV(env);
611 ENSURE_HAS_CAP(env, can_access_local_variables);
612 return MethodUtil::SetLocalVariable(env, thread, depth, slot, value);
613 }
614
SetLocalDouble(jvmtiEnv * env,jthread thread,jint depth,jint slot,jdouble value)615 static jvmtiError SetLocalDouble(jvmtiEnv* env,
616 jthread thread,
617 jint depth,
618 jint slot,
619 jdouble value) {
620 ENSURE_VALID_ENV(env);
621 ENSURE_HAS_CAP(env, can_access_local_variables);
622 return MethodUtil::SetLocalVariable(env, thread, depth, slot, value);
623 }
624
625
SetBreakpoint(jvmtiEnv * env,jmethodID method,jlocation location)626 static jvmtiError SetBreakpoint(jvmtiEnv* env, jmethodID method, jlocation location) {
627 ENSURE_VALID_ENV(env);
628 ENSURE_HAS_CAP(env, can_generate_breakpoint_events);
629 return BreakpointUtil::SetBreakpoint(env, method, location);
630 }
631
ClearBreakpoint(jvmtiEnv * env,jmethodID method,jlocation location)632 static jvmtiError ClearBreakpoint(jvmtiEnv* env, jmethodID method, jlocation location) {
633 ENSURE_VALID_ENV(env);
634 ENSURE_HAS_CAP(env, can_generate_breakpoint_events);
635 return BreakpointUtil::ClearBreakpoint(env, method, location);
636 }
637
SetFieldAccessWatch(jvmtiEnv * env,jclass klass,jfieldID field)638 static jvmtiError SetFieldAccessWatch(jvmtiEnv* env, jclass klass, jfieldID field) {
639 ENSURE_VALID_ENV(env);
640 ENSURE_HAS_CAP(env, can_generate_field_access_events);
641 return FieldUtil::SetFieldAccessWatch(env, klass, field);
642 }
643
ClearFieldAccessWatch(jvmtiEnv * env,jclass klass,jfieldID field)644 static jvmtiError ClearFieldAccessWatch(jvmtiEnv* env, jclass klass, jfieldID field) {
645 ENSURE_VALID_ENV(env);
646 ENSURE_HAS_CAP(env, can_generate_field_access_events);
647 return FieldUtil::ClearFieldAccessWatch(env, klass, field);
648 }
649
SetFieldModificationWatch(jvmtiEnv * env,jclass klass,jfieldID field)650 static jvmtiError SetFieldModificationWatch(jvmtiEnv* env, jclass klass, jfieldID field) {
651 ENSURE_VALID_ENV(env);
652 ENSURE_HAS_CAP(env, can_generate_field_modification_events);
653 return FieldUtil::SetFieldModificationWatch(env, klass, field);
654 }
655
ClearFieldModificationWatch(jvmtiEnv * env,jclass klass,jfieldID field)656 static jvmtiError ClearFieldModificationWatch(jvmtiEnv* env, jclass klass, jfieldID field) {
657 ENSURE_VALID_ENV(env);
658 ENSURE_HAS_CAP(env, can_generate_field_modification_events);
659 return FieldUtil::ClearFieldModificationWatch(env, klass, field);
660 }
661
GetLoadedClasses(jvmtiEnv * env,jint * class_count_ptr,jclass ** classes_ptr)662 static jvmtiError GetLoadedClasses(jvmtiEnv* env, jint* class_count_ptr, jclass** classes_ptr) {
663 ENSURE_VALID_ENV(env);
664 HeapUtil heap_util(ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table.get());
665 return heap_util.GetLoadedClasses(env, class_count_ptr, classes_ptr);
666 }
667
GetClassLoaderClasses(jvmtiEnv * env,jobject initiating_loader,jint * class_count_ptr,jclass ** classes_ptr)668 static jvmtiError GetClassLoaderClasses(jvmtiEnv* env,
669 jobject initiating_loader,
670 jint* class_count_ptr,
671 jclass** classes_ptr) {
672 ENSURE_VALID_ENV(env);
673 return ClassUtil::GetClassLoaderClasses(env, initiating_loader, class_count_ptr, classes_ptr);
674 }
675
GetClassSignature(jvmtiEnv * env,jclass klass,char ** signature_ptr,char ** generic_ptr)676 static jvmtiError GetClassSignature(jvmtiEnv* env,
677 jclass klass,
678 char** signature_ptr,
679 char** generic_ptr) {
680 ENSURE_VALID_ENV(env);
681 return ClassUtil::GetClassSignature(env, klass, signature_ptr, generic_ptr);
682 }
683
GetClassStatus(jvmtiEnv * env,jclass klass,jint * status_ptr)684 static jvmtiError GetClassStatus(jvmtiEnv* env, jclass klass, jint* status_ptr) {
685 ENSURE_VALID_ENV(env);
686 return ClassUtil::GetClassStatus(env, klass, status_ptr);
687 }
688
GetSourceFileName(jvmtiEnv * env,jclass klass,char ** source_name_ptr)689 static jvmtiError GetSourceFileName(jvmtiEnv* env, jclass klass, char** source_name_ptr) {
690 ENSURE_VALID_ENV(env);
691 ENSURE_HAS_CAP(env, can_get_source_file_name);
692 return ClassUtil::GetSourceFileName(env, klass, source_name_ptr);
693 }
694
GetClassModifiers(jvmtiEnv * env,jclass klass,jint * modifiers_ptr)695 static jvmtiError GetClassModifiers(jvmtiEnv* env, jclass klass, jint* modifiers_ptr) {
696 ENSURE_VALID_ENV(env);
697 return ClassUtil::GetClassModifiers(env, klass, modifiers_ptr);
698 }
699
GetClassMethods(jvmtiEnv * env,jclass klass,jint * method_count_ptr,jmethodID ** methods_ptr)700 static jvmtiError GetClassMethods(jvmtiEnv* env,
701 jclass klass,
702 jint* method_count_ptr,
703 jmethodID** methods_ptr) {
704 ENSURE_VALID_ENV(env);
705 return ClassUtil::GetClassMethods(env, klass, method_count_ptr, methods_ptr);
706 }
707
GetClassFields(jvmtiEnv * env,jclass klass,jint * field_count_ptr,jfieldID ** fields_ptr)708 static jvmtiError GetClassFields(jvmtiEnv* env,
709 jclass klass,
710 jint* field_count_ptr,
711 jfieldID** fields_ptr) {
712 ENSURE_VALID_ENV(env);
713 return ClassUtil::GetClassFields(env, klass, field_count_ptr, fields_ptr);
714 }
715
GetImplementedInterfaces(jvmtiEnv * env,jclass klass,jint * interface_count_ptr,jclass ** interfaces_ptr)716 static jvmtiError GetImplementedInterfaces(jvmtiEnv* env,
717 jclass klass,
718 jint* interface_count_ptr,
719 jclass** interfaces_ptr) {
720 ENSURE_VALID_ENV(env);
721 return ClassUtil::GetImplementedInterfaces(env, klass, interface_count_ptr, interfaces_ptr);
722 }
723
GetClassVersionNumbers(jvmtiEnv * env,jclass klass,jint * minor_version_ptr,jint * major_version_ptr)724 static jvmtiError GetClassVersionNumbers(jvmtiEnv* env,
725 jclass klass,
726 jint* minor_version_ptr,
727 jint* major_version_ptr) {
728 ENSURE_VALID_ENV(env);
729 return ClassUtil::GetClassVersionNumbers(env, klass, minor_version_ptr, major_version_ptr);
730 }
731
GetConstantPool(jvmtiEnv * env,jclass klass,jint * constant_pool_count_ptr,jint * constant_pool_byte_count_ptr,unsigned char ** constant_pool_bytes_ptr)732 static jvmtiError GetConstantPool(jvmtiEnv* env,
733 [[maybe_unused]] jclass klass,
734 [[maybe_unused]] jint* constant_pool_count_ptr,
735 [[maybe_unused]] jint* constant_pool_byte_count_ptr,
736 [[maybe_unused]] unsigned char** constant_pool_bytes_ptr) {
737 ENSURE_VALID_ENV(env);
738 ENSURE_HAS_CAP(env, can_get_constant_pool);
739 return ERR(NOT_IMPLEMENTED);
740 }
741
IsInterface(jvmtiEnv * env,jclass klass,jboolean * is_interface_ptr)742 static jvmtiError IsInterface(jvmtiEnv* env, jclass klass, jboolean* is_interface_ptr) {
743 ENSURE_VALID_ENV(env);
744 return ClassUtil::IsInterface(env, klass, is_interface_ptr);
745 }
746
IsArrayClass(jvmtiEnv * env,jclass klass,jboolean * is_array_class_ptr)747 static jvmtiError IsArrayClass(jvmtiEnv* env,
748 jclass klass,
749 jboolean* is_array_class_ptr) {
750 ENSURE_VALID_ENV(env);
751 return ClassUtil::IsArrayClass(env, klass, is_array_class_ptr);
752 }
753
IsModifiableClass(jvmtiEnv * env,jclass klass,jboolean * is_modifiable_class_ptr)754 static jvmtiError IsModifiableClass(jvmtiEnv* env,
755 jclass klass,
756 jboolean* is_modifiable_class_ptr) {
757 ENSURE_VALID_ENV(env);
758 return Redefiner::IsModifiableClass(env, klass, is_modifiable_class_ptr);
759 }
760
GetClassLoader(jvmtiEnv * env,jclass klass,jobject * classloader_ptr)761 static jvmtiError GetClassLoader(jvmtiEnv* env, jclass klass, jobject* classloader_ptr) {
762 ENSURE_VALID_ENV(env);
763 return ClassUtil::GetClassLoader(env, klass, classloader_ptr);
764 }
765
GetSourceDebugExtension(jvmtiEnv * env,jclass klass,char ** source_debug_extension_ptr)766 static jvmtiError GetSourceDebugExtension(jvmtiEnv* env,
767 jclass klass,
768 char** source_debug_extension_ptr) {
769 ENSURE_VALID_ENV(env);
770 ENSURE_HAS_CAP(env, can_get_source_debug_extension);
771 return ClassUtil::GetSourceDebugExtension(env, klass, source_debug_extension_ptr);
772 }
773
RetransformClasses(jvmtiEnv * env,jint class_count,const jclass * classes)774 static jvmtiError RetransformClasses(jvmtiEnv* env, jint class_count, const jclass* classes) {
775 ENSURE_VALID_ENV(env);
776 ENSURE_HAS_CAP(env, can_retransform_classes);
777 return Transformer::RetransformClasses(env, class_count, classes);
778 }
779
RedefineClasses(jvmtiEnv * env,jint class_count,const jvmtiClassDefinition * class_definitions)780 static jvmtiError RedefineClasses(jvmtiEnv* env,
781 jint class_count,
782 const jvmtiClassDefinition* class_definitions) {
783 ENSURE_VALID_ENV(env);
784 ENSURE_HAS_CAP(env, can_redefine_classes);
785 return Redefiner::RedefineClasses(env, class_count, class_definitions);
786 }
787
GetObjectSize(jvmtiEnv * env,jobject object,jlong * size_ptr)788 static jvmtiError GetObjectSize(jvmtiEnv* env, jobject object, jlong* size_ptr) {
789 ENSURE_VALID_ENV(env);
790 return ObjectUtil::GetObjectSize(env, object, size_ptr);
791 }
792
GetObjectHashCode(jvmtiEnv * env,jobject object,jint * hash_code_ptr)793 static jvmtiError GetObjectHashCode(jvmtiEnv* env, jobject object, jint* hash_code_ptr) {
794 ENSURE_VALID_ENV(env);
795 return ObjectUtil::GetObjectHashCode(env, object, hash_code_ptr);
796 }
797
GetObjectMonitorUsage(jvmtiEnv * env,jobject object,jvmtiMonitorUsage * info_ptr)798 static jvmtiError GetObjectMonitorUsage(jvmtiEnv* env,
799 jobject object,
800 jvmtiMonitorUsage* info_ptr) {
801 ENSURE_VALID_ENV(env);
802 ENSURE_HAS_CAP(env, can_get_monitor_info);
803 return ObjectUtil::GetObjectMonitorUsage(env, object, info_ptr);
804 }
805
GetFieldName(jvmtiEnv * env,jclass klass,jfieldID field,char ** name_ptr,char ** signature_ptr,char ** generic_ptr)806 static jvmtiError GetFieldName(jvmtiEnv* env,
807 jclass klass,
808 jfieldID field,
809 char** name_ptr,
810 char** signature_ptr,
811 char** generic_ptr) {
812 ENSURE_VALID_ENV(env);
813 return FieldUtil::GetFieldName(env, klass, field, name_ptr, signature_ptr, generic_ptr);
814 }
815
GetFieldDeclaringClass(jvmtiEnv * env,jclass klass,jfieldID field,jclass * declaring_class_ptr)816 static jvmtiError GetFieldDeclaringClass(jvmtiEnv* env,
817 jclass klass,
818 jfieldID field,
819 jclass* declaring_class_ptr) {
820 ENSURE_VALID_ENV(env);
821 return FieldUtil::GetFieldDeclaringClass(env, klass, field, declaring_class_ptr);
822 }
823
GetFieldModifiers(jvmtiEnv * env,jclass klass,jfieldID field,jint * modifiers_ptr)824 static jvmtiError GetFieldModifiers(jvmtiEnv* env,
825 jclass klass,
826 jfieldID field,
827 jint* modifiers_ptr) {
828 ENSURE_VALID_ENV(env);
829 return FieldUtil::GetFieldModifiers(env, klass, field, modifiers_ptr);
830 }
831
IsFieldSynthetic(jvmtiEnv * env,jclass klass,jfieldID field,jboolean * is_synthetic_ptr)832 static jvmtiError IsFieldSynthetic(jvmtiEnv* env,
833 jclass klass,
834 jfieldID field,
835 jboolean* is_synthetic_ptr) {
836 ENSURE_VALID_ENV(env);
837 ENSURE_HAS_CAP(env, can_get_synthetic_attribute);
838 return FieldUtil::IsFieldSynthetic(env, klass, field, is_synthetic_ptr);
839 }
840
GetMethodName(jvmtiEnv * env,jmethodID method,char ** name_ptr,char ** signature_ptr,char ** generic_ptr)841 static jvmtiError GetMethodName(jvmtiEnv* env,
842 jmethodID method,
843 char** name_ptr,
844 char** signature_ptr,
845 char** generic_ptr) {
846 ENSURE_VALID_ENV(env);
847 return MethodUtil::GetMethodName(env, method, name_ptr, signature_ptr, generic_ptr);
848 }
849
GetMethodDeclaringClass(jvmtiEnv * env,jmethodID method,jclass * declaring_class_ptr)850 static jvmtiError GetMethodDeclaringClass(jvmtiEnv* env,
851 jmethodID method,
852 jclass* declaring_class_ptr) {
853 ENSURE_VALID_ENV(env);
854 return MethodUtil::GetMethodDeclaringClass(env, method, declaring_class_ptr);
855 }
856
GetMethodModifiers(jvmtiEnv * env,jmethodID method,jint * modifiers_ptr)857 static jvmtiError GetMethodModifiers(jvmtiEnv* env,
858 jmethodID method,
859 jint* modifiers_ptr) {
860 ENSURE_VALID_ENV(env);
861 return MethodUtil::GetMethodModifiers(env, method, modifiers_ptr);
862 }
863
GetMaxLocals(jvmtiEnv * env,jmethodID method,jint * max_ptr)864 static jvmtiError GetMaxLocals(jvmtiEnv* env,
865 jmethodID method,
866 jint* max_ptr) {
867 ENSURE_VALID_ENV(env);
868 return MethodUtil::GetMaxLocals(env, method, max_ptr);
869 }
870
GetArgumentsSize(jvmtiEnv * env,jmethodID method,jint * size_ptr)871 static jvmtiError GetArgumentsSize(jvmtiEnv* env,
872 jmethodID method,
873 jint* size_ptr) {
874 ENSURE_VALID_ENV(env);
875 return MethodUtil::GetArgumentsSize(env, method, size_ptr);
876 }
877
GetLineNumberTable(jvmtiEnv * env,jmethodID method,jint * entry_count_ptr,jvmtiLineNumberEntry ** table_ptr)878 static jvmtiError GetLineNumberTable(jvmtiEnv* env,
879 jmethodID method,
880 jint* entry_count_ptr,
881 jvmtiLineNumberEntry** table_ptr) {
882 ENSURE_VALID_ENV(env);
883 ENSURE_HAS_CAP(env, can_get_line_numbers);
884 return MethodUtil::GetLineNumberTable(env, method, entry_count_ptr, table_ptr);
885 }
886
GetMethodLocation(jvmtiEnv * env,jmethodID method,jlocation * start_location_ptr,jlocation * end_location_ptr)887 static jvmtiError GetMethodLocation(jvmtiEnv* env,
888 jmethodID method,
889 jlocation* start_location_ptr,
890 jlocation* end_location_ptr) {
891 ENSURE_VALID_ENV(env);
892 return MethodUtil::GetMethodLocation(env, method, start_location_ptr, end_location_ptr);
893 }
894
GetLocalVariableTable(jvmtiEnv * env,jmethodID method,jint * entry_count_ptr,jvmtiLocalVariableEntry ** table_ptr)895 static jvmtiError GetLocalVariableTable(jvmtiEnv* env,
896 jmethodID method,
897 jint* entry_count_ptr,
898 jvmtiLocalVariableEntry** table_ptr) {
899 ENSURE_VALID_ENV(env);
900 ENSURE_HAS_CAP(env, can_access_local_variables);
901 return MethodUtil::GetLocalVariableTable(env, method, entry_count_ptr, table_ptr);
902 }
903
GetBytecodes(jvmtiEnv * env,jmethodID method,jint * bytecode_count_ptr,unsigned char ** bytecodes_ptr)904 static jvmtiError GetBytecodes(jvmtiEnv* env,
905 jmethodID method,
906 jint* bytecode_count_ptr,
907 unsigned char** bytecodes_ptr) {
908 ENSURE_VALID_ENV(env);
909 ENSURE_HAS_CAP(env, can_get_bytecodes);
910 return MethodUtil::GetBytecodes(env, method, bytecode_count_ptr, bytecodes_ptr);
911 }
912
IsMethodNative(jvmtiEnv * env,jmethodID method,jboolean * is_native_ptr)913 static jvmtiError IsMethodNative(jvmtiEnv* env, jmethodID method, jboolean* is_native_ptr) {
914 ENSURE_VALID_ENV(env);
915 return MethodUtil::IsMethodNative(env, method, is_native_ptr);
916 }
917
IsMethodSynthetic(jvmtiEnv * env,jmethodID method,jboolean * is_synthetic_ptr)918 static jvmtiError IsMethodSynthetic(jvmtiEnv* env, jmethodID method, jboolean* is_synthetic_ptr) {
919 ENSURE_VALID_ENV(env);
920 ENSURE_HAS_CAP(env, can_get_synthetic_attribute);
921 return MethodUtil::IsMethodSynthetic(env, method, is_synthetic_ptr);
922 }
923
IsMethodObsolete(jvmtiEnv * env,jmethodID method,jboolean * is_obsolete_ptr)924 static jvmtiError IsMethodObsolete(jvmtiEnv* env, jmethodID method, jboolean* is_obsolete_ptr) {
925 ENSURE_VALID_ENV(env);
926 return MethodUtil::IsMethodObsolete(env, method, is_obsolete_ptr);
927 }
928
SetNativeMethodPrefix(jvmtiEnv * env,const char * prefix)929 static jvmtiError SetNativeMethodPrefix(jvmtiEnv* env, [[maybe_unused]] const char* prefix) {
930 ENSURE_VALID_ENV(env);
931 ENSURE_HAS_CAP(env, can_set_native_method_prefix);
932 return ERR(NOT_IMPLEMENTED);
933 }
934
SetNativeMethodPrefixes(jvmtiEnv * env,jint prefix_count,char ** prefixes)935 static jvmtiError SetNativeMethodPrefixes(jvmtiEnv* env,
936 [[maybe_unused]] jint prefix_count,
937 [[maybe_unused]] char** prefixes) {
938 ENSURE_VALID_ENV(env);
939 ENSURE_HAS_CAP(env, can_set_native_method_prefix);
940 return ERR(NOT_IMPLEMENTED);
941 }
942
CreateRawMonitor(jvmtiEnv * env,const char * name,jrawMonitorID * monitor_ptr)943 static jvmtiError CreateRawMonitor(jvmtiEnv* env, const char* name, jrawMonitorID* monitor_ptr) {
944 ENSURE_VALID_ENV(env);
945 return MonitorUtil::CreateRawMonitor(env, name, monitor_ptr);
946 }
947
DestroyRawMonitor(jvmtiEnv * env,jrawMonitorID monitor)948 static jvmtiError DestroyRawMonitor(jvmtiEnv* env, jrawMonitorID monitor) {
949 ENSURE_VALID_ENV(env);
950 return MonitorUtil::DestroyRawMonitor(env, monitor);
951 }
952
RawMonitorEnter(jvmtiEnv * env,jrawMonitorID monitor)953 static jvmtiError RawMonitorEnter(jvmtiEnv* env, jrawMonitorID monitor) {
954 ENSURE_VALID_ENV(env);
955 return MonitorUtil::RawMonitorEnter(env, monitor);
956 }
957
RawMonitorExit(jvmtiEnv * env,jrawMonitorID monitor)958 static jvmtiError RawMonitorExit(jvmtiEnv* env, jrawMonitorID monitor) {
959 ENSURE_VALID_ENV(env);
960 return MonitorUtil::RawMonitorExit(env, monitor);
961 }
962
RawMonitorWait(jvmtiEnv * env,jrawMonitorID monitor,jlong millis)963 static jvmtiError RawMonitorWait(jvmtiEnv* env, jrawMonitorID monitor, jlong millis) {
964 ENSURE_VALID_ENV(env);
965 return MonitorUtil::RawMonitorWait(env, monitor, millis);
966 }
967
RawMonitorNotify(jvmtiEnv * env,jrawMonitorID monitor)968 static jvmtiError RawMonitorNotify(jvmtiEnv* env, jrawMonitorID monitor) {
969 ENSURE_VALID_ENV(env);
970 return MonitorUtil::RawMonitorNotify(env, monitor);
971 }
972
RawMonitorNotifyAll(jvmtiEnv * env,jrawMonitorID monitor)973 static jvmtiError RawMonitorNotifyAll(jvmtiEnv* env, jrawMonitorID monitor) {
974 ENSURE_VALID_ENV(env);
975 return MonitorUtil::RawMonitorNotifyAll(env, monitor);
976 }
977
SetJNIFunctionTable(jvmtiEnv * env,const jniNativeInterface * function_table)978 static jvmtiError SetJNIFunctionTable(jvmtiEnv* env, const jniNativeInterface* function_table) {
979 ENSURE_VALID_ENV(env);
980 return JNIUtil::SetJNIFunctionTable(env, function_table);
981 }
982
GetJNIFunctionTable(jvmtiEnv * env,jniNativeInterface ** function_table)983 static jvmtiError GetJNIFunctionTable(jvmtiEnv* env, jniNativeInterface** function_table) {
984 ENSURE_VALID_ENV(env);
985 return JNIUtil::GetJNIFunctionTable(env, function_table);
986 }
987
988 // TODO: This will require locking, so that an agent can't remove callbacks when we're dispatching
989 // an event.
SetEventCallbacks(jvmtiEnv * env,const jvmtiEventCallbacks * callbacks,jint size_of_callbacks)990 static jvmtiError SetEventCallbacks(jvmtiEnv* env,
991 const jvmtiEventCallbacks* callbacks,
992 jint size_of_callbacks) {
993 ENSURE_VALID_ENV(env);
994 if (size_of_callbacks < 0) {
995 return ERR(ILLEGAL_ARGUMENT);
996 }
997
998 if (callbacks == nullptr) {
999 ArtJvmTiEnv::AsArtJvmTiEnv(env)->event_callbacks.reset();
1000 return ERR(NONE);
1001 }
1002
1003 // Lock the event_info_mutex_ while we replace the callbacks.
1004 ArtJvmTiEnv* art_env = ArtJvmTiEnv::AsArtJvmTiEnv(env);
1005 art::WriterMutexLock lk(art::Thread::Current(), art_env->event_info_mutex_);
1006 std::unique_ptr<ArtJvmtiEventCallbacks> tmp(new ArtJvmtiEventCallbacks());
1007 // Copy over the extension events.
1008 tmp->CopyExtensionsFrom(art_env->event_callbacks.get());
1009 // Never overwrite the extension events.
1010 size_t copy_size = std::min(sizeof(jvmtiEventCallbacks),
1011 static_cast<size_t>(size_of_callbacks));
1012 copy_size = art::RoundDown(copy_size, sizeof(void*));
1013 // Copy non-extension events.
1014 memcpy(tmp.get(), callbacks, copy_size);
1015
1016 // replace the event table.
1017 art_env->event_callbacks = std::move(tmp);
1018
1019 return ERR(NONE);
1020 }
1021
SetEventNotificationMode(jvmtiEnv * env,jvmtiEventMode mode,jvmtiEvent event_type,jthread event_thread,...)1022 static jvmtiError SetEventNotificationMode(jvmtiEnv* env,
1023 jvmtiEventMode mode,
1024 jvmtiEvent event_type,
1025 jthread event_thread,
1026 ...) {
1027 ENSURE_VALID_ENV(env);
1028 ArtJvmTiEnv* art_env = ArtJvmTiEnv::AsArtJvmTiEnv(env);
1029 return gEventHandler->SetEvent(art_env,
1030 event_thread,
1031 GetArtJvmtiEvent(art_env, event_type),
1032 mode);
1033 }
1034
GenerateEvents(jvmtiEnv * env,jvmtiEvent event_type)1035 static jvmtiError GenerateEvents(jvmtiEnv* env, [[maybe_unused]] jvmtiEvent event_type) {
1036 ENSURE_VALID_ENV(env);
1037 return OK;
1038 }
1039
GetExtensionFunctions(jvmtiEnv * env,jint * extension_count_ptr,jvmtiExtensionFunctionInfo ** extensions)1040 static jvmtiError GetExtensionFunctions(jvmtiEnv* env,
1041 jint* extension_count_ptr,
1042 jvmtiExtensionFunctionInfo** extensions) {
1043 ENSURE_VALID_ENV(env);
1044 ENSURE_NON_NULL(extension_count_ptr);
1045 ENSURE_NON_NULL(extensions);
1046 return ExtensionUtil::GetExtensionFunctions(env, extension_count_ptr, extensions);
1047 }
1048
GetExtensionEvents(jvmtiEnv * env,jint * extension_count_ptr,jvmtiExtensionEventInfo ** extensions)1049 static jvmtiError GetExtensionEvents(jvmtiEnv* env,
1050 jint* extension_count_ptr,
1051 jvmtiExtensionEventInfo** extensions) {
1052 ENSURE_VALID_ENV(env);
1053 ENSURE_NON_NULL(extension_count_ptr);
1054 ENSURE_NON_NULL(extensions);
1055 return ExtensionUtil::GetExtensionEvents(env, extension_count_ptr, extensions);
1056 }
1057
SetExtensionEventCallback(jvmtiEnv * env,jint extension_event_index,jvmtiExtensionEvent callback)1058 static jvmtiError SetExtensionEventCallback(jvmtiEnv* env,
1059 jint extension_event_index,
1060 jvmtiExtensionEvent callback) {
1061 ENSURE_VALID_ENV(env);
1062 return ExtensionUtil::SetExtensionEventCallback(env,
1063 extension_event_index,
1064 callback,
1065 gEventHandler);
1066 }
1067
1068 #define FOR_ALL_CAPABILITIES(FUN) \
1069 FUN(can_tag_objects) \
1070 FUN(can_generate_field_modification_events) \
1071 FUN(can_generate_field_access_events) \
1072 FUN(can_get_bytecodes) \
1073 FUN(can_get_synthetic_attribute) \
1074 FUN(can_get_owned_monitor_info) \
1075 FUN(can_get_current_contended_monitor) \
1076 FUN(can_get_monitor_info) \
1077 FUN(can_pop_frame) \
1078 FUN(can_redefine_classes) \
1079 FUN(can_signal_thread) \
1080 FUN(can_get_source_file_name) \
1081 FUN(can_get_line_numbers) \
1082 FUN(can_get_source_debug_extension) \
1083 FUN(can_access_local_variables) \
1084 FUN(can_maintain_original_method_order) \
1085 FUN(can_generate_single_step_events) \
1086 FUN(can_generate_exception_events) \
1087 FUN(can_generate_frame_pop_events) \
1088 FUN(can_generate_breakpoint_events) \
1089 FUN(can_suspend) \
1090 FUN(can_redefine_any_class) \
1091 FUN(can_get_current_thread_cpu_time) \
1092 FUN(can_get_thread_cpu_time) \
1093 FUN(can_generate_method_entry_events) \
1094 FUN(can_generate_method_exit_events) \
1095 FUN(can_generate_all_class_hook_events) \
1096 FUN(can_generate_compiled_method_load_events) \
1097 FUN(can_generate_monitor_events) \
1098 FUN(can_generate_vm_object_alloc_events) \
1099 FUN(can_generate_native_method_bind_events) \
1100 FUN(can_generate_garbage_collection_events) \
1101 FUN(can_generate_object_free_events) \
1102 FUN(can_force_early_return) \
1103 FUN(can_get_owned_monitor_stack_depth_info) \
1104 FUN(can_get_constant_pool) \
1105 FUN(can_set_native_method_prefix) \
1106 FUN(can_retransform_classes) \
1107 FUN(can_retransform_any_class) \
1108 FUN(can_generate_resource_exhaustion_heap_events) \
1109 FUN(can_generate_resource_exhaustion_threads_events)
1110
GetPotentialCapabilities(jvmtiEnv * env,jvmtiCapabilities * capabilities_ptr)1111 static jvmtiError GetPotentialCapabilities(jvmtiEnv* env, jvmtiCapabilities* capabilities_ptr) {
1112 ENSURE_VALID_ENV(env);
1113 ENSURE_NON_NULL(capabilities_ptr);
1114 *capabilities_ptr = kPotentialCapabilities;
1115 if (UNLIKELY(!IsFullJvmtiAvailable())) {
1116 #define REMOVE_NONDEBUGGABLE_UNSUPPORTED(e) \
1117 do { \
1118 if (kNonDebuggableUnsupportedCapabilities.e == 1) { \
1119 capabilities_ptr->e = 0; \
1120 } \
1121 } while (false);
1122
1123 FOR_ALL_CAPABILITIES(REMOVE_NONDEBUGGABLE_UNSUPPORTED);
1124 #undef REMOVE_NONDEBUGGABLE_UNSUPPORTED
1125 }
1126 return OK;
1127 }
1128
AddCapabilities(jvmtiEnv * env,const jvmtiCapabilities * capabilities_ptr)1129 static jvmtiError AddCapabilities(jvmtiEnv* env, const jvmtiCapabilities* capabilities_ptr) {
1130 ENSURE_VALID_ENV(env);
1131 ENSURE_NON_NULL(capabilities_ptr);
1132 ArtJvmTiEnv* art_env = static_cast<ArtJvmTiEnv*>(env);
1133 jvmtiError ret = OK;
1134 jvmtiCapabilities changed = {};
1135 jvmtiCapabilities potential_capabilities = {};
1136 ret = env->GetPotentialCapabilities(&potential_capabilities);
1137 if (ret != OK) {
1138 return ret;
1139 }
1140 #define ADD_CAPABILITY(e) \
1141 do { \
1142 if (capabilities_ptr->e == 1) { \
1143 if (potential_capabilities.e == 1) { \
1144 if (art_env->capabilities.e != 1) { \
1145 art_env->capabilities.e = 1; \
1146 changed.e = 1; \
1147 }\
1148 } else { \
1149 ret = ERR(NOT_AVAILABLE); \
1150 } \
1151 } \
1152 } while (false);
1153
1154 FOR_ALL_CAPABILITIES(ADD_CAPABILITY);
1155 #undef ADD_CAPABILITY
1156 gEventHandler->HandleChangedCapabilities(ArtJvmTiEnv::AsArtJvmTiEnv(env),
1157 changed,
1158 /*added=*/true);
1159 return ret;
1160 }
1161
RelinquishCapabilities(jvmtiEnv * env,const jvmtiCapabilities * capabilities_ptr)1162 static jvmtiError RelinquishCapabilities(jvmtiEnv* env,
1163 const jvmtiCapabilities* capabilities_ptr) {
1164 ENSURE_VALID_ENV(env);
1165 ENSURE_NON_NULL(capabilities_ptr);
1166 ArtJvmTiEnv* art_env = reinterpret_cast<ArtJvmTiEnv*>(env);
1167 jvmtiCapabilities changed = {};
1168 #define DEL_CAPABILITY(e) \
1169 do { \
1170 if (capabilities_ptr->e == 1) { \
1171 if (art_env->capabilities.e == 1) { \
1172 art_env->capabilities.e = 0;\
1173 changed.e = 1; \
1174 } \
1175 } \
1176 } while (false);
1177
1178 FOR_ALL_CAPABILITIES(DEL_CAPABILITY);
1179 #undef DEL_CAPABILITY
1180 gEventHandler->HandleChangedCapabilities(ArtJvmTiEnv::AsArtJvmTiEnv(env),
1181 changed,
1182 /*added=*/false);
1183 return OK;
1184 }
1185
1186 #undef FOR_ALL_CAPABILITIES
1187
GetCapabilities(jvmtiEnv * env,jvmtiCapabilities * capabilities_ptr)1188 static jvmtiError GetCapabilities(jvmtiEnv* env, jvmtiCapabilities* capabilities_ptr) {
1189 ENSURE_VALID_ENV(env);
1190 ENSURE_NON_NULL(capabilities_ptr);
1191 ArtJvmTiEnv* artenv = reinterpret_cast<ArtJvmTiEnv*>(env);
1192 *capabilities_ptr = artenv->capabilities;
1193 return OK;
1194 }
1195
GetCurrentThreadCpuTimerInfo(jvmtiEnv * env,jvmtiTimerInfo * info_ptr)1196 static jvmtiError GetCurrentThreadCpuTimerInfo(jvmtiEnv* env,
1197 [[maybe_unused]] jvmtiTimerInfo* info_ptr) {
1198 ENSURE_VALID_ENV(env);
1199 ENSURE_HAS_CAP(env, can_get_current_thread_cpu_time);
1200 return ERR(NOT_IMPLEMENTED);
1201 }
1202
GetCurrentThreadCpuTime(jvmtiEnv * env,jlong * nanos_ptr)1203 static jvmtiError GetCurrentThreadCpuTime(jvmtiEnv* env, [[maybe_unused]] jlong* nanos_ptr) {
1204 ENSURE_VALID_ENV(env);
1205 ENSURE_HAS_CAP(env, can_get_current_thread_cpu_time);
1206 return ERR(NOT_IMPLEMENTED);
1207 }
1208
GetThreadCpuTimerInfo(jvmtiEnv * env,jvmtiTimerInfo * info_ptr)1209 static jvmtiError GetThreadCpuTimerInfo(jvmtiEnv* env,
1210 [[maybe_unused]] jvmtiTimerInfo* info_ptr) {
1211 ENSURE_VALID_ENV(env);
1212 ENSURE_HAS_CAP(env, can_get_thread_cpu_time);
1213 return ERR(NOT_IMPLEMENTED);
1214 }
1215
GetThreadCpuTime(jvmtiEnv * env,jthread thread,jlong * nanos_ptr)1216 static jvmtiError GetThreadCpuTime(jvmtiEnv* env,
1217 [[maybe_unused]] jthread thread,
1218 [[maybe_unused]] jlong* nanos_ptr) {
1219 ENSURE_VALID_ENV(env);
1220 ENSURE_HAS_CAP(env, can_get_thread_cpu_time);
1221 return ERR(NOT_IMPLEMENTED);
1222 }
1223
GetTimerInfo(jvmtiEnv * env,jvmtiTimerInfo * info_ptr)1224 static jvmtiError GetTimerInfo(jvmtiEnv* env, jvmtiTimerInfo* info_ptr) {
1225 ENSURE_VALID_ENV(env);
1226 return TimerUtil::GetTimerInfo(env, info_ptr);
1227 }
1228
GetTime(jvmtiEnv * env,jlong * nanos_ptr)1229 static jvmtiError GetTime(jvmtiEnv* env, jlong* nanos_ptr) {
1230 ENSURE_VALID_ENV(env);
1231 return TimerUtil::GetTime(env, nanos_ptr);
1232 }
1233
GetAvailableProcessors(jvmtiEnv * env,jint * processor_count_ptr)1234 static jvmtiError GetAvailableProcessors(jvmtiEnv* env, jint* processor_count_ptr) {
1235 ENSURE_VALID_ENV(env);
1236 return TimerUtil::GetAvailableProcessors(env, processor_count_ptr);
1237 }
1238
AddToBootstrapClassLoaderSearch(jvmtiEnv * env,const char * segment)1239 static jvmtiError AddToBootstrapClassLoaderSearch(jvmtiEnv* env, const char* segment) {
1240 ENSURE_VALID_ENV(env);
1241 return SearchUtil::AddToBootstrapClassLoaderSearch(env, segment);
1242 }
1243
AddToSystemClassLoaderSearch(jvmtiEnv * env,const char * segment)1244 static jvmtiError AddToSystemClassLoaderSearch(jvmtiEnv* env, const char* segment) {
1245 ENSURE_VALID_ENV(env);
1246 return SearchUtil::AddToSystemClassLoaderSearch(env, segment);
1247 }
1248
GetSystemProperties(jvmtiEnv * env,jint * count_ptr,char *** property_ptr)1249 static jvmtiError GetSystemProperties(jvmtiEnv* env, jint* count_ptr, char*** property_ptr) {
1250 ENSURE_VALID_ENV(env);
1251 return PropertiesUtil::GetSystemProperties(env, count_ptr, property_ptr);
1252 }
1253
GetSystemProperty(jvmtiEnv * env,const char * property,char ** value_ptr)1254 static jvmtiError GetSystemProperty(jvmtiEnv* env, const char* property, char** value_ptr) {
1255 ENSURE_VALID_ENV(env);
1256 return PropertiesUtil::GetSystemProperty(env, property, value_ptr);
1257 }
1258
SetSystemProperty(jvmtiEnv * env,const char * property,const char * value)1259 static jvmtiError SetSystemProperty(jvmtiEnv* env, const char* property, const char* value) {
1260 ENSURE_VALID_ENV(env);
1261 return PropertiesUtil::SetSystemProperty(env, property, value);
1262 }
1263
GetPhase(jvmtiEnv * env,jvmtiPhase * phase_ptr)1264 static jvmtiError GetPhase(jvmtiEnv* env, jvmtiPhase* phase_ptr) {
1265 ENSURE_VALID_ENV(env);
1266 return PhaseUtil::GetPhase(env, phase_ptr);
1267 }
1268
DisposeEnvironment(jvmtiEnv * env)1269 static jvmtiError DisposeEnvironment(jvmtiEnv* env) {
1270 ENSURE_VALID_ENV(env);
1271 ArtJvmTiEnv* tienv = ArtJvmTiEnv::AsArtJvmTiEnv(env);
1272 gEventHandler->RemoveArtJvmTiEnv(tienv);
1273 art::Runtime::Current()->RemoveSystemWeakHolder(tienv->object_tag_table.get());
1274 ThreadUtil::RemoveEnvironment(tienv);
1275 delete tienv;
1276 return OK;
1277 }
1278
SetEnvironmentLocalStorage(jvmtiEnv * env,const void * data)1279 static jvmtiError SetEnvironmentLocalStorage(jvmtiEnv* env, const void* data) {
1280 ENSURE_VALID_ENV(env);
1281 reinterpret_cast<ArtJvmTiEnv*>(env)->local_data = const_cast<void*>(data);
1282 return OK;
1283 }
1284
GetEnvironmentLocalStorage(jvmtiEnv * env,void ** data_ptr)1285 static jvmtiError GetEnvironmentLocalStorage(jvmtiEnv* env, void** data_ptr) {
1286 ENSURE_VALID_ENV(env);
1287 *data_ptr = reinterpret_cast<ArtJvmTiEnv*>(env)->local_data;
1288 return OK;
1289 }
1290
GetVersionNumber(jvmtiEnv * env,jint * version_ptr)1291 static jvmtiError GetVersionNumber(jvmtiEnv* env, jint* version_ptr) {
1292 ENSURE_VALID_ENV(env);
1293 *version_ptr = ArtJvmTiEnv::AsArtJvmTiEnv(env)->ti_version;
1294 return OK;
1295 }
1296
GetErrorName(jvmtiEnv * env,jvmtiError error,char ** name_ptr)1297 static jvmtiError GetErrorName(jvmtiEnv* env, jvmtiError error, char** name_ptr) {
1298 ENSURE_NON_NULL(name_ptr);
1299 auto copy_fn = [&](const char* name_cstr) {
1300 jvmtiError res;
1301 JvmtiUniquePtr<char[]> copy = CopyString(env, name_cstr, &res);
1302 if (copy == nullptr) {
1303 *name_ptr = nullptr;
1304 return res;
1305 } else {
1306 *name_ptr = copy.release();
1307 return OK;
1308 }
1309 };
1310 switch (error) {
1311 #define ERROR_CASE(e) case (JVMTI_ERROR_ ## e) : \
1312 return copy_fn("JVMTI_ERROR_"#e);
1313 ERROR_CASE(NONE);
1314 ERROR_CASE(INVALID_THREAD);
1315 ERROR_CASE(INVALID_THREAD_GROUP);
1316 ERROR_CASE(INVALID_PRIORITY);
1317 ERROR_CASE(THREAD_NOT_SUSPENDED);
1318 ERROR_CASE(THREAD_SUSPENDED);
1319 ERROR_CASE(THREAD_NOT_ALIVE);
1320 ERROR_CASE(INVALID_OBJECT);
1321 ERROR_CASE(INVALID_CLASS);
1322 ERROR_CASE(CLASS_NOT_PREPARED);
1323 ERROR_CASE(INVALID_METHODID);
1324 ERROR_CASE(INVALID_LOCATION);
1325 ERROR_CASE(INVALID_FIELDID);
1326 ERROR_CASE(NO_MORE_FRAMES);
1327 ERROR_CASE(OPAQUE_FRAME);
1328 ERROR_CASE(TYPE_MISMATCH);
1329 ERROR_CASE(INVALID_SLOT);
1330 ERROR_CASE(DUPLICATE);
1331 ERROR_CASE(NOT_FOUND);
1332 ERROR_CASE(INVALID_MONITOR);
1333 ERROR_CASE(NOT_MONITOR_OWNER);
1334 ERROR_CASE(INTERRUPT);
1335 ERROR_CASE(INVALID_CLASS_FORMAT);
1336 ERROR_CASE(CIRCULAR_CLASS_DEFINITION);
1337 ERROR_CASE(FAILS_VERIFICATION);
1338 ERROR_CASE(UNSUPPORTED_REDEFINITION_METHOD_ADDED);
1339 ERROR_CASE(UNSUPPORTED_REDEFINITION_SCHEMA_CHANGED);
1340 ERROR_CASE(INVALID_TYPESTATE);
1341 ERROR_CASE(UNSUPPORTED_REDEFINITION_HIERARCHY_CHANGED);
1342 ERROR_CASE(UNSUPPORTED_REDEFINITION_METHOD_DELETED);
1343 ERROR_CASE(UNSUPPORTED_VERSION);
1344 ERROR_CASE(NAMES_DONT_MATCH);
1345 ERROR_CASE(UNSUPPORTED_REDEFINITION_CLASS_MODIFIERS_CHANGED);
1346 ERROR_CASE(UNSUPPORTED_REDEFINITION_METHOD_MODIFIERS_CHANGED);
1347 ERROR_CASE(UNMODIFIABLE_CLASS);
1348 ERROR_CASE(NOT_AVAILABLE);
1349 ERROR_CASE(MUST_POSSESS_CAPABILITY);
1350 ERROR_CASE(NULL_POINTER);
1351 ERROR_CASE(ABSENT_INFORMATION);
1352 ERROR_CASE(INVALID_EVENT_TYPE);
1353 ERROR_CASE(ILLEGAL_ARGUMENT);
1354 ERROR_CASE(NATIVE_METHOD);
1355 ERROR_CASE(CLASS_LOADER_UNSUPPORTED);
1356 ERROR_CASE(OUT_OF_MEMORY);
1357 ERROR_CASE(ACCESS_DENIED);
1358 ERROR_CASE(WRONG_PHASE);
1359 ERROR_CASE(INTERNAL);
1360 ERROR_CASE(UNATTACHED_THREAD);
1361 ERROR_CASE(INVALID_ENVIRONMENT);
1362 #undef ERROR_CASE
1363 }
1364
1365 return ERR(ILLEGAL_ARGUMENT);
1366 }
1367
SetVerboseFlag(jvmtiEnv * env,jvmtiVerboseFlag flag,jboolean value)1368 static jvmtiError SetVerboseFlag(jvmtiEnv* env,
1369 jvmtiVerboseFlag flag,
1370 jboolean value) {
1371 ENSURE_VALID_ENV(env);
1372 return LogUtil::SetVerboseFlag(env, flag, value);
1373 }
1374
GetJLocationFormat(jvmtiEnv * env,jvmtiJlocationFormat * format_ptr)1375 static jvmtiError GetJLocationFormat(jvmtiEnv* env, jvmtiJlocationFormat* format_ptr) {
1376 ENSURE_VALID_ENV(env);
1377 // Report BCI as jlocation format. We report dex bytecode indices.
1378 if (format_ptr == nullptr) {
1379 return ERR(NULL_POINTER);
1380 }
1381 *format_ptr = jvmtiJlocationFormat::JVMTI_JLOCATION_JVMBCI;
1382 return ERR(NONE);
1383 }
1384 };
1385
IsJvmtiVersion(jint version)1386 static bool IsJvmtiVersion(jint version) {
1387 return version == JVMTI_VERSION_1 ||
1388 version == JVMTI_VERSION_1_0 ||
1389 version == JVMTI_VERSION_1_1 ||
1390 version == JVMTI_VERSION_1_2 ||
1391 version == JVMTI_VERSION;
1392 }
1393
1394 extern const jvmtiInterface_1 gJvmtiInterface;
1395
ArtJvmTiEnv(art::JavaVMExt * runtime,EventHandler * event_handler,jint version)1396 ArtJvmTiEnv::ArtJvmTiEnv(art::JavaVMExt* runtime, EventHandler* event_handler, jint version)
1397 : art_vm(runtime),
1398 local_data(nullptr),
1399 ti_version(version),
1400 capabilities(),
1401 event_info_mutex_("jvmtiEnv_EventInfoMutex"),
1402 last_error_mutex_("jvmtiEnv_LastErrorMutex", art::LockLevel::kGenericBottomLock) {
1403 object_tag_table = std::make_unique<ObjectTagTable>(event_handler, this);
1404 functions = &gJvmtiInterface;
1405 }
1406
1407 // Creates a jvmtiEnv and returns it with the art::ti::Env that is associated with it. new_art_ti
1408 // is a pointer to the uninitialized memory for an art::ti::Env.
CreateArtJvmTiEnv(art::JavaVMExt * vm,jint version,void ** new_jvmtiEnv)1409 static void CreateArtJvmTiEnv(art::JavaVMExt* vm, jint version, /*out*/void** new_jvmtiEnv) {
1410 struct ArtJvmTiEnv* env = new ArtJvmTiEnv(vm, gEventHandler, version);
1411 *new_jvmtiEnv = env;
1412
1413 gEventHandler->RegisterArtJvmTiEnv(env);
1414
1415 art::Runtime::Current()->AddSystemWeakHolder(
1416 ArtJvmTiEnv::AsArtJvmTiEnv(env)->object_tag_table.get());
1417 }
1418
1419 // A hook that the runtime uses to allow plugins to handle GetEnv calls. It returns true and
1420 // places the return value in 'env' if this library can handle the GetEnv request. Otherwise
1421 // returns false and does not modify the 'env' pointer.
GetEnvHandler(art::JavaVMExt * vm,void ** env,jint version)1422 static jint GetEnvHandler(art::JavaVMExt* vm, /*out*/void** env, jint version) {
1423 // JavaDebuggable will either be set by the runtime as it is starting up or the plugin if it's
1424 // loaded early enough. If this is false we cannot guarantee conformance to all JVMTI behaviors
1425 // due to optimizations. We will only allow agents to get ArtTiEnvs using the kArtTiVersion.
1426 if (IsFullJvmtiAvailable() && IsJvmtiVersion(version)) {
1427 CreateArtJvmTiEnv(vm, JVMTI_VERSION, env);
1428 return JNI_OK;
1429 } else if (version == kArtTiVersion) {
1430 CreateArtJvmTiEnv(vm, kArtTiVersion, env);
1431 return JNI_OK;
1432 } else {
1433 printf("version 0x%x is not valid!", version);
1434 if (IsJvmtiVersion(version)) {
1435 LOG(ERROR) << "JVMTI Version 0x" << std::hex << version << " requested but the runtime is not"
1436 << " debuggable! Only limited, best effort kArtTiVersion"
1437 << " (0x" << std::hex << kArtTiVersion << ") environments are available. If"
1438 << " possible, rebuild your apk in debuggable mode or start the runtime with"
1439 << " the `-Xcompiler-option --debuggable` flags.";
1440 }
1441 return JNI_EVERSION;
1442 }
1443 }
1444
1445 // The plugin initialization function. This adds the jvmti environment.
ArtPlugin_Initialize()1446 extern "C" bool ArtPlugin_Initialize() {
1447 art::Runtime* runtime = art::Runtime::Current();
1448
1449 gAllocManager = new AllocationManager;
1450 gDeoptManager = new DeoptManager;
1451 gEventHandler = new EventHandler;
1452
1453 gDeoptManager->Setup();
1454 if (runtime->IsStarted()) {
1455 PhaseUtil::SetToLive();
1456 } else {
1457 PhaseUtil::SetToOnLoad();
1458 }
1459 PhaseUtil::Register(gEventHandler);
1460 ThreadUtil::Register(gEventHandler);
1461 ClassUtil::Register(gEventHandler);
1462 DumpUtil::Register(gEventHandler);
1463 MethodUtil::Register(gEventHandler);
1464 HeapExtensions::Register(gEventHandler);
1465 SearchUtil::Register();
1466 HeapUtil::Register();
1467 FieldUtil::Register(gEventHandler);
1468 BreakpointUtil::Register(gEventHandler);
1469 Transformer::Register(gEventHandler);
1470 gDeoptManager->FinishSetup();
1471 runtime->GetJavaVM()->AddEnvironmentHook(GetEnvHandler);
1472
1473 return true;
1474 }
1475
ArtPlugin_Deinitialize()1476 extern "C" bool ArtPlugin_Deinitialize() {
1477 // When runtime is shutting down, it is not necessary to unregister callbacks or update
1478 // instrumentation levels. Removing callbacks require a GC critical section in some cases and
1479 // when runtime is shutting down we already stop GC and hence it is not safe to request to
1480 // enter a GC critical section.
1481 if (art::Runtime::Current()->IsShuttingDown(art::Thread::Current())) {
1482 return true;
1483 }
1484
1485 gEventHandler->Shutdown();
1486 gDeoptManager->Shutdown();
1487 PhaseUtil::Unregister();
1488 ThreadUtil::Unregister();
1489 ClassUtil::Unregister();
1490 DumpUtil::Unregister();
1491 MethodUtil::Unregister();
1492 SearchUtil::Unregister();
1493 HeapUtil::Unregister();
1494 FieldUtil::Unregister();
1495 BreakpointUtil::Unregister();
1496
1497 // TODO It would be good to delete the gEventHandler and gDeoptManager here but we cannot since
1498 // daemon threads might be suspended and we want to make sure that even if they wake up briefly
1499 // they won't hit deallocated memory. By this point none of the functions will do anything since
1500 // they have already shutdown.
1501
1502 return true;
1503 }
1504
1505 // The actual struct holding all of the entrypoints into the jvmti interface.
1506 const jvmtiInterface_1 gJvmtiInterface = {
1507 nullptr, // reserved1
1508 JvmtiFunctions::SetEventNotificationMode,
1509 nullptr, // reserved3
1510 JvmtiFunctions::GetAllThreads,
1511 JvmtiFunctions::SuspendThread,
1512 JvmtiFunctions::ResumeThread,
1513 JvmtiFunctions::StopThread,
1514 JvmtiFunctions::InterruptThread,
1515 JvmtiFunctions::GetThreadInfo,
1516 JvmtiFunctions::GetOwnedMonitorInfo, // 10
1517 JvmtiFunctions::GetCurrentContendedMonitor,
1518 JvmtiFunctions::RunAgentThread,
1519 JvmtiFunctions::GetTopThreadGroups,
1520 JvmtiFunctions::GetThreadGroupInfo,
1521 JvmtiFunctions::GetThreadGroupChildren,
1522 JvmtiFunctions::GetFrameCount,
1523 JvmtiFunctions::GetThreadState,
1524 JvmtiFunctions::GetCurrentThread,
1525 JvmtiFunctions::GetFrameLocation,
1526 JvmtiFunctions::NotifyFramePop, // 20
1527 JvmtiFunctions::GetLocalObject,
1528 JvmtiFunctions::GetLocalInt,
1529 JvmtiFunctions::GetLocalLong,
1530 JvmtiFunctions::GetLocalFloat,
1531 JvmtiFunctions::GetLocalDouble,
1532 JvmtiFunctions::SetLocalObject,
1533 JvmtiFunctions::SetLocalInt,
1534 JvmtiFunctions::SetLocalLong,
1535 JvmtiFunctions::SetLocalFloat,
1536 JvmtiFunctions::SetLocalDouble, // 30
1537 JvmtiFunctions::CreateRawMonitor,
1538 JvmtiFunctions::DestroyRawMonitor,
1539 JvmtiFunctions::RawMonitorEnter,
1540 JvmtiFunctions::RawMonitorExit,
1541 JvmtiFunctions::RawMonitorWait,
1542 JvmtiFunctions::RawMonitorNotify,
1543 JvmtiFunctions::RawMonitorNotifyAll,
1544 JvmtiFunctions::SetBreakpoint,
1545 JvmtiFunctions::ClearBreakpoint,
1546 nullptr, // reserved40
1547 JvmtiFunctions::SetFieldAccessWatch,
1548 JvmtiFunctions::ClearFieldAccessWatch,
1549 JvmtiFunctions::SetFieldModificationWatch,
1550 JvmtiFunctions::ClearFieldModificationWatch,
1551 JvmtiFunctions::IsModifiableClass,
1552 JvmtiFunctions::Allocate,
1553 JvmtiFunctions::Deallocate,
1554 JvmtiFunctions::GetClassSignature,
1555 JvmtiFunctions::GetClassStatus,
1556 JvmtiFunctions::GetSourceFileName, // 50
1557 JvmtiFunctions::GetClassModifiers,
1558 JvmtiFunctions::GetClassMethods,
1559 JvmtiFunctions::GetClassFields,
1560 JvmtiFunctions::GetImplementedInterfaces,
1561 JvmtiFunctions::IsInterface,
1562 JvmtiFunctions::IsArrayClass,
1563 JvmtiFunctions::GetClassLoader,
1564 JvmtiFunctions::GetObjectHashCode,
1565 JvmtiFunctions::GetObjectMonitorUsage,
1566 JvmtiFunctions::GetFieldName, // 60
1567 JvmtiFunctions::GetFieldDeclaringClass,
1568 JvmtiFunctions::GetFieldModifiers,
1569 JvmtiFunctions::IsFieldSynthetic,
1570 JvmtiFunctions::GetMethodName,
1571 JvmtiFunctions::GetMethodDeclaringClass,
1572 JvmtiFunctions::GetMethodModifiers,
1573 nullptr, // reserved67
1574 JvmtiFunctions::GetMaxLocals,
1575 JvmtiFunctions::GetArgumentsSize,
1576 JvmtiFunctions::GetLineNumberTable, // 70
1577 JvmtiFunctions::GetMethodLocation,
1578 JvmtiFunctions::GetLocalVariableTable,
1579 JvmtiFunctions::SetNativeMethodPrefix,
1580 JvmtiFunctions::SetNativeMethodPrefixes,
1581 JvmtiFunctions::GetBytecodes,
1582 JvmtiFunctions::IsMethodNative,
1583 JvmtiFunctions::IsMethodSynthetic,
1584 JvmtiFunctions::GetLoadedClasses,
1585 JvmtiFunctions::GetClassLoaderClasses,
1586 JvmtiFunctions::PopFrame, // 80
1587 JvmtiFunctions::ForceEarlyReturnObject,
1588 JvmtiFunctions::ForceEarlyReturnInt,
1589 JvmtiFunctions::ForceEarlyReturnLong,
1590 JvmtiFunctions::ForceEarlyReturnFloat,
1591 JvmtiFunctions::ForceEarlyReturnDouble,
1592 JvmtiFunctions::ForceEarlyReturnVoid,
1593 JvmtiFunctions::RedefineClasses,
1594 JvmtiFunctions::GetVersionNumber,
1595 JvmtiFunctions::GetCapabilities,
1596 JvmtiFunctions::GetSourceDebugExtension, // 90
1597 JvmtiFunctions::IsMethodObsolete,
1598 JvmtiFunctions::SuspendThreadList,
1599 JvmtiFunctions::ResumeThreadList,
1600 nullptr, // reserved94
1601 nullptr, // reserved95
1602 nullptr, // reserved96
1603 nullptr, // reserved97
1604 nullptr, // reserved98
1605 nullptr, // reserved99
1606 JvmtiFunctions::GetAllStackTraces, // 100
1607 JvmtiFunctions::GetThreadListStackTraces,
1608 JvmtiFunctions::GetThreadLocalStorage,
1609 JvmtiFunctions::SetThreadLocalStorage,
1610 JvmtiFunctions::GetStackTrace,
1611 nullptr, // reserved105
1612 JvmtiFunctions::GetTag,
1613 JvmtiFunctions::SetTag,
1614 JvmtiFunctions::ForceGarbageCollection,
1615 JvmtiFunctions::IterateOverObjectsReachableFromObject,
1616 JvmtiFunctions::IterateOverReachableObjects, // 110
1617 JvmtiFunctions::IterateOverHeap,
1618 JvmtiFunctions::IterateOverInstancesOfClass,
1619 nullptr, // reserved113
1620 JvmtiFunctions::GetObjectsWithTags,
1621 JvmtiFunctions::FollowReferences,
1622 JvmtiFunctions::IterateThroughHeap,
1623 nullptr, // reserved117
1624 nullptr, // reserved118
1625 nullptr, // reserved119
1626 JvmtiFunctions::SetJNIFunctionTable, // 120
1627 JvmtiFunctions::GetJNIFunctionTable,
1628 JvmtiFunctions::SetEventCallbacks,
1629 JvmtiFunctions::GenerateEvents,
1630 JvmtiFunctions::GetExtensionFunctions,
1631 JvmtiFunctions::GetExtensionEvents,
1632 JvmtiFunctions::SetExtensionEventCallback,
1633 JvmtiFunctions::DisposeEnvironment,
1634 JvmtiFunctions::GetErrorName,
1635 JvmtiFunctions::GetJLocationFormat,
1636 JvmtiFunctions::GetSystemProperties, // 130
1637 JvmtiFunctions::GetSystemProperty,
1638 JvmtiFunctions::SetSystemProperty,
1639 JvmtiFunctions::GetPhase,
1640 JvmtiFunctions::GetCurrentThreadCpuTimerInfo,
1641 JvmtiFunctions::GetCurrentThreadCpuTime,
1642 JvmtiFunctions::GetThreadCpuTimerInfo,
1643 JvmtiFunctions::GetThreadCpuTime,
1644 JvmtiFunctions::GetTimerInfo,
1645 JvmtiFunctions::GetTime,
1646 JvmtiFunctions::GetPotentialCapabilities, // 140
1647 nullptr, // reserved141
1648 JvmtiFunctions::AddCapabilities,
1649 JvmtiFunctions::RelinquishCapabilities,
1650 JvmtiFunctions::GetAvailableProcessors,
1651 JvmtiFunctions::GetClassVersionNumbers,
1652 JvmtiFunctions::GetConstantPool,
1653 JvmtiFunctions::GetEnvironmentLocalStorage,
1654 JvmtiFunctions::SetEnvironmentLocalStorage,
1655 JvmtiFunctions::AddToBootstrapClassLoaderSearch,
1656 JvmtiFunctions::SetVerboseFlag, // 150
1657 JvmtiFunctions::AddToSystemClassLoaderSearch,
1658 JvmtiFunctions::RetransformClasses,
1659 JvmtiFunctions::GetOwnedMonitorStackDepthInfo,
1660 JvmtiFunctions::GetObjectSize,
1661 JvmtiFunctions::GetLocalInstance,
1662 };
1663
1664 }; // namespace openjdkjvmti
1665