xref: /aosp_15_r20/cts/hostsidetests/jvmti/base/jni/cts_logging.cpp (revision b7c941bb3fa97aba169d73cee0bed2de8ac964bf)
1*b7c941bbSAndroid Build Coastguard Worker /*
2*b7c941bbSAndroid Build Coastguard Worker  * Copyright (C) 2017 The Android Open Source Project
3*b7c941bbSAndroid Build Coastguard Worker  *
4*b7c941bbSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*b7c941bbSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*b7c941bbSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*b7c941bbSAndroid Build Coastguard Worker  *
8*b7c941bbSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*b7c941bbSAndroid Build Coastguard Worker  *
10*b7c941bbSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*b7c941bbSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*b7c941bbSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*b7c941bbSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*b7c941bbSAndroid Build Coastguard Worker  * limitations under the License.
15*b7c941bbSAndroid Build Coastguard Worker  */
16*b7c941bbSAndroid Build Coastguard Worker 
17*b7c941bbSAndroid Build Coastguard Worker #include <jni.h>
18*b7c941bbSAndroid Build Coastguard Worker #include <jvmti.h>
19*b7c941bbSAndroid Build Coastguard Worker 
20*b7c941bbSAndroid Build Coastguard Worker #include "android-base/logging.h"
21*b7c941bbSAndroid Build Coastguard Worker #include "jni_binder.h"
22*b7c941bbSAndroid Build Coastguard Worker #include "jvmti_helper.h"
23*b7c941bbSAndroid Build Coastguard Worker #include "scoped_local_ref.h"
24*b7c941bbSAndroid Build Coastguard Worker #include "test_env.h"
25*b7c941bbSAndroid Build Coastguard Worker 
26*b7c941bbSAndroid Build Coastguard Worker namespace art {
27*b7c941bbSAndroid Build Coastguard Worker 
28*b7c941bbSAndroid Build Coastguard Worker typedef jvmtiError (*SetVerboseFlagExt)(jvmtiEnv*, const char*, jboolean);
29*b7c941bbSAndroid Build Coastguard Worker extern "C" JNIEXPORT void JNICALL
Java_android_jvmti_cts_JvmtiRunTestBasedTest_setupExtraLogging(JNIEnv * env,jclass,jstring arg)30*b7c941bbSAndroid Build Coastguard Worker Java_android_jvmti_cts_JvmtiRunTestBasedTest_setupExtraLogging(JNIEnv* env, jclass, jstring arg) {
31*b7c941bbSAndroid Build Coastguard Worker   SetVerboseFlagExt set_flag_ext = GetExtensionFunction<SetVerboseFlagExt>(
32*b7c941bbSAndroid Build Coastguard Worker       env, jvmti_env, "com.android.art.misc.set_verbose_flag_ext");
33*b7c941bbSAndroid Build Coastguard Worker   if (set_flag_ext == nullptr) {
34*b7c941bbSAndroid Build Coastguard Worker     // Just do backup and enable everything.
35*b7c941bbSAndroid Build Coastguard Worker     JvmtiErrorToException(env, jvmti_env, jvmti_env->SetVerboseFlag(JVMTI_VERBOSE_OTHER, true));
36*b7c941bbSAndroid Build Coastguard Worker   } else {
37*b7c941bbSAndroid Build Coastguard Worker     // UTFChars doesn't need to be null terminated.
38*b7c941bbSAndroid Build Coastguard Worker     const char* data_raw = env->GetStringUTFChars(arg, nullptr);
39*b7c941bbSAndroid Build Coastguard Worker     std::string data;
40*b7c941bbSAndroid Build Coastguard Worker     data.resize(env->GetStringUTFLength(arg));
41*b7c941bbSAndroid Build Coastguard Worker     memcpy(data.data(), data_raw, data.size());
42*b7c941bbSAndroid Build Coastguard Worker     env->ReleaseStringUTFChars(arg, data_raw);
43*b7c941bbSAndroid Build Coastguard Worker     JvmtiErrorToException(env, jvmti_env, set_flag_ext(jvmti_env, data.c_str(), true));
44*b7c941bbSAndroid Build Coastguard Worker   }
45*b7c941bbSAndroid Build Coastguard Worker }
46*b7c941bbSAndroid Build Coastguard Worker 
47*b7c941bbSAndroid Build Coastguard Worker static JNINativeMethod gMethods[] = {
48*b7c941bbSAndroid Build Coastguard Worker   { "setupExtraLogging",
49*b7c941bbSAndroid Build Coastguard Worker     "(Ljava/lang/String;)V",
50*b7c941bbSAndroid Build Coastguard Worker     (void*)Java_android_jvmti_cts_JvmtiRunTestBasedTest_setupExtraLogging },
51*b7c941bbSAndroid Build Coastguard Worker };
register_android_jvmti_cts_JvmtiRunTestBasedTest(jvmtiEnv * jenv,JNIEnv * env)52*b7c941bbSAndroid Build Coastguard Worker void register_android_jvmti_cts_JvmtiRunTestBasedTest(jvmtiEnv* jenv, JNIEnv* env) {
53*b7c941bbSAndroid Build Coastguard Worker   ScopedLocalRef<jclass> klass(
54*b7c941bbSAndroid Build Coastguard Worker       env, GetClass(jenv, env, "android/jvmti/cts/JvmtiRunTestBasedTest", nullptr));
55*b7c941bbSAndroid Build Coastguard Worker   if (klass.get() == nullptr) {
56*b7c941bbSAndroid Build Coastguard Worker     env->ExceptionClear();
57*b7c941bbSAndroid Build Coastguard Worker     return;
58*b7c941bbSAndroid Build Coastguard Worker   }
59*b7c941bbSAndroid Build Coastguard Worker 
60*b7c941bbSAndroid Build Coastguard Worker   env->RegisterNatives(klass.get(), gMethods, sizeof(gMethods) / sizeof(JNINativeMethod));
61*b7c941bbSAndroid Build Coastguard Worker   if (env->ExceptionCheck()) {
62*b7c941bbSAndroid Build Coastguard Worker     env->ExceptionClear();
63*b7c941bbSAndroid Build Coastguard Worker     LOG(ERROR) << "Could not register natives for JvmtiRedefineClassesTest class";
64*b7c941bbSAndroid Build Coastguard Worker   }
65*b7c941bbSAndroid Build Coastguard Worker }
66*b7c941bbSAndroid Build Coastguard Worker 
67*b7c941bbSAndroid Build Coastguard Worker }  // namespace art
68