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