1/* 2 * Copyright (C) 2011 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17#include "jni_internal.h" 18 19#include <dlfcn.h> 20 21#include <cstdarg> 22#include <memory> 23#include <utility> 24#include <vector> 25 26#include "art_field-inl.h" 27#include "art_method-inl.h" 28#include "atomic.h" 29#include "base/allocator.h" 30#include "base/logging.h" 31#include "base/mutex.h" 32#include "base/stl_util.h" 33#include "class_linker-inl.h" 34#include "dex_file-inl.h" 35#include "fault_handler.h" 36#include "gc_root.h" 37#include "gc/accounting/card_table-inl.h" 38#include "indirect_reference_table-inl.h" 39#include "interpreter/interpreter.h" 40#include "jni_env_ext.h" 41#include "java_vm_ext.h" 42#include "mirror/class-inl.h" 43#include "mirror/class_loader.h" 44#include "mirror/field-inl.h" 45#include "mirror/method.h" 46#include "mirror/object-inl.h" 47#include "mirror/object_array-inl.h" 48#include "mirror/string-inl.h" 49#include "mirror/throwable.h" 50#include "parsed_options.h" 51#include "reflection.h" 52#include "runtime.h" 53#include "safe_map.h" 54#include "scoped_thread_state_change.h" 55#include "ScopedLocalRef.h" 56#include "thread.h" 57#include "utf.h" 58#include "well_known_classes.h" 59 60namespace art { 61 62// Consider turning this on when there is errors which could be related to JNI array copies such as 63// things not rendering correctly. E.g. b/16858794 64static constexpr bool kWarnJniAbort = false; 65 66// Section 12.3.2 of the JNI spec describes JNI class descriptors. They're 67// separated with slashes but aren't wrapped with "L;" like regular descriptors 68// (i.e. "a/b/C" rather than "La/b/C;"). Arrays of reference types are an 69// exception; there the "L;" must be present ("[La/b/C;"). Historically we've 70// supported names with dots too (such as "a.b.C"). 71static std::string NormalizeJniClassDescriptor(const char* name) { 72 std::string result; 73 // Add the missing "L;" if necessary. 74 if (name[0] == '[') { 75 result = name; 76 } else { 77 result += 'L'; 78 result += name; 79 result += ';'; 80 } 81 // Rewrite '.' as '/' for backwards compatibility. 82 if (result.find('.') != std::string::npos) { 83 LOG(WARNING) << "Call to JNI FindClass with dots in name: " 84 << "\"" << name << "\""; 85 std::replace(result.begin(), result.end(), '.', '/'); 86 } 87 return result; 88} 89 90static void ThrowNoSuchMethodError(ScopedObjectAccess& soa, mirror::Class* c, 91 const char* name, const char* sig, const char* kind) 92 SHARED_REQUIRES(Locks::mutator_lock_) { 93 std::string temp; 94 soa.Self()->ThrowNewExceptionF("Ljava/lang/NoSuchMethodError;", 95 "no %s method \"%s.%s%s\"", 96 kind, c->GetDescriptor(&temp), name, sig); 97} 98 99static void ReportInvalidJNINativeMethod(const ScopedObjectAccess& soa, mirror::Class* c, 100 const char* kind, jint idx, bool return_errors) 101 SHARED_REQUIRES(Locks::mutator_lock_) { 102 LOG(return_errors ? ERROR : FATAL) << "Failed to register native method in " 103 << PrettyDescriptor(c) << " in " << c->GetDexCache()->GetLocation()->ToModifiedUtf8() 104 << ": " << kind << " is null at index " << idx; 105 soa.Self()->ThrowNewExceptionF("Ljava/lang/NoSuchMethodError;", 106 "%s is null at index %d", kind, idx); 107} 108 109static mirror::Class* EnsureInitialized(Thread* self, mirror::Class* klass) 110 SHARED_REQUIRES(Locks::mutator_lock_) { 111 if (LIKELY(klass->IsInitialized())) { 112 return klass; 113 } 114 StackHandleScope<1> hs(self); 115 Handle<mirror::Class> h_klass(hs.NewHandle(klass)); 116 if (!Runtime::Current()->GetClassLinker()->EnsureInitialized(self, h_klass, true, true)) { 117 return nullptr; 118 } 119 return h_klass.Get(); 120} 121 122static jmethodID FindMethodID(ScopedObjectAccess& soa, jclass jni_class, 123 const char* name, const char* sig, bool is_static) 124 SHARED_REQUIRES(Locks::mutator_lock_) { 125 mirror::Class* c = EnsureInitialized(soa.Self(), soa.Decode<mirror::Class*>(jni_class)); 126 if (c == nullptr) { 127 return nullptr; 128 } 129 ArtMethod* method = nullptr; 130 auto pointer_size = Runtime::Current()->GetClassLinker()->GetImagePointerSize(); 131 if (is_static) { 132 method = c->FindDirectMethod(name, sig, pointer_size); 133 } else if (c->IsInterface()) { 134 method = c->FindInterfaceMethod(name, sig, pointer_size); 135 } else { 136 method = c->FindVirtualMethod(name, sig, pointer_size); 137 if (method == nullptr) { 138 // No virtual method matching the signature. Search declared 139 // private methods and constructors. 140 method = c->FindDeclaredDirectMethod(name, sig, pointer_size); 141 } 142 } 143 if (method == nullptr || method->IsStatic() != is_static) { 144 ThrowNoSuchMethodError(soa, c, name, sig, is_static ? "static" : "non-static"); 145 return nullptr; 146 } 147 return soa.EncodeMethod(method); 148} 149 150static mirror::ClassLoader* GetClassLoader(const ScopedObjectAccess& soa) 151 SHARED_REQUIRES(Locks::mutator_lock_) { 152 ArtMethod* method = soa.Self()->GetCurrentMethod(nullptr); 153 // If we are running Runtime.nativeLoad, use the overriding ClassLoader it set. 154 if (method == soa.DecodeMethod(WellKnownClasses::java_lang_Runtime_nativeLoad)) { 155 return soa.Decode<mirror::ClassLoader*>(soa.Self()->GetClassLoaderOverride()); 156 } 157 // If we have a method, use its ClassLoader for context. 158 if (method != nullptr) { 159 return method->GetDeclaringClass()->GetClassLoader(); 160 } 161 // We don't have a method, so try to use the system ClassLoader. 162 mirror::ClassLoader* class_loader = 163 soa.Decode<mirror::ClassLoader*>(Runtime::Current()->GetSystemClassLoader()); 164 if (class_loader != nullptr) { 165 return class_loader; 166 } 167 // See if the override ClassLoader is set for gtests. 168 class_loader = soa.Decode<mirror::ClassLoader*>(soa.Self()->GetClassLoaderOverride()); 169 if (class_loader != nullptr) { 170 // If so, CommonCompilerTest should have marked the runtime as a compiler not compiling an 171 // image. 172 CHECK(Runtime::Current()->IsAotCompiler()); 173 CHECK(!Runtime::Current()->IsCompilingBootImage()); 174 return class_loader; 175 } 176 // Use the BOOTCLASSPATH. 177 return nullptr; 178} 179 180static jfieldID FindFieldID(const ScopedObjectAccess& soa, jclass jni_class, const char* name, 181 const char* sig, bool is_static) 182 SHARED_REQUIRES(Locks::mutator_lock_) { 183 StackHandleScope<2> hs(soa.Self()); 184 Handle<mirror::Class> c( 185 hs.NewHandle(EnsureInitialized(soa.Self(), soa.Decode<mirror::Class*>(jni_class)))); 186 if (c.Get() == nullptr) { 187 return nullptr; 188 } 189 ArtField* field = nullptr; 190 mirror::Class* field_type; 191 ClassLinker* class_linker = Runtime::Current()->GetClassLinker(); 192 if (sig[1] != '\0') { 193 Handle<mirror::ClassLoader> class_loader(hs.NewHandle(c->GetClassLoader())); 194 field_type = class_linker->FindClass(soa.Self(), sig, class_loader); 195 } else { 196 field_type = class_linker->FindPrimitiveClass(*sig); 197 } 198 if (field_type == nullptr) { 199 // Failed to find type from the signature of the field. 200 DCHECK(soa.Self()->IsExceptionPending()); 201 StackHandleScope<1> hs2(soa.Self()); 202 Handle<mirror::Throwable> cause(hs2.NewHandle(soa.Self()->GetException())); 203 soa.Self()->ClearException(); 204 std::string temp; 205 soa.Self()->ThrowNewExceptionF("Ljava/lang/NoSuchFieldError;", 206 "no type \"%s\" found and so no field \"%s\" " 207 "could be found in class \"%s\" or its superclasses", sig, name, 208 c->GetDescriptor(&temp)); 209 soa.Self()->GetException()->SetCause(cause.Get()); 210 return nullptr; 211 } 212 std::string temp; 213 if (is_static) { 214 field = mirror::Class::FindStaticField(soa.Self(), c, name, 215 field_type->GetDescriptor(&temp)); 216 } else { 217 field = c->FindInstanceField(name, field_type->GetDescriptor(&temp)); 218 } 219 if (field == nullptr) { 220 soa.Self()->ThrowNewExceptionF("Ljava/lang/NoSuchFieldError;", 221 "no \"%s\" field \"%s\" in class \"%s\" or its superclasses", 222 sig, name, c->GetDescriptor(&temp)); 223 return nullptr; 224 } 225 return soa.EncodeField(field); 226} 227 228static void ThrowAIOOBE(ScopedObjectAccess& soa, mirror::Array* array, jsize start, 229 jsize length, const char* identifier) 230 SHARED_REQUIRES(Locks::mutator_lock_) { 231 std::string type(PrettyTypeOf(array)); 232 soa.Self()->ThrowNewExceptionF("Ljava/lang/ArrayIndexOutOfBoundsException;", 233 "%s offset=%d length=%d %s.length=%d", 234 type.c_str(), start, length, identifier, array->GetLength()); 235} 236 237static void ThrowSIOOBE(ScopedObjectAccess& soa, jsize start, jsize length, 238 jsize array_length) 239 SHARED_REQUIRES(Locks::mutator_lock_) { 240 soa.Self()->ThrowNewExceptionF("Ljava/lang/StringIndexOutOfBoundsException;", 241 "offset=%d length=%d string.length()=%d", start, length, 242 array_length); 243} 244 245int ThrowNewException(JNIEnv* env, jclass exception_class, const char* msg, jobject cause) 246 REQUIRES(!Locks::mutator_lock_) { 247 // Turn the const char* into a java.lang.String. 248 ScopedLocalRef<jstring> s(env, env->NewStringUTF(msg)); 249 if (msg != nullptr && s.get() == nullptr) { 250 return JNI_ERR; 251 } 252 253 // Choose an appropriate constructor and set up the arguments. 254 jvalue args[2]; 255 const char* signature; 256 if (msg == nullptr && cause == nullptr) { 257 signature = "()V"; 258 } else if (msg != nullptr && cause == nullptr) { 259 signature = "(Ljava/lang/String;)V"; 260 args[0].l = s.get(); 261 } else if (msg == nullptr && cause != nullptr) { 262 signature = "(Ljava/lang/Throwable;)V"; 263 args[0].l = cause; 264 } else { 265 signature = "(Ljava/lang/String;Ljava/lang/Throwable;)V"; 266 args[0].l = s.get(); 267 args[1].l = cause; 268 } 269 jmethodID mid = env->GetMethodID(exception_class, "<init>", signature); 270 if (mid == nullptr) { 271 ScopedObjectAccess soa(env); 272 LOG(ERROR) << "No <init>" << signature << " in " 273 << PrettyClass(soa.Decode<mirror::Class*>(exception_class)); 274 return JNI_ERR; 275 } 276 277 ScopedLocalRef<jthrowable> exception( 278 env, reinterpret_cast<jthrowable>(env->NewObjectA(exception_class, mid, args))); 279 if (exception.get() == nullptr) { 280 return JNI_ERR; 281 } 282 ScopedObjectAccess soa(env); 283 soa.Self()->SetException(soa.Decode<mirror::Throwable*>(exception.get())); 284 return JNI_OK; 285} 286 287static JavaVMExt* JavaVmExtFromEnv(JNIEnv* env) { 288 return reinterpret_cast<JNIEnvExt*>(env)->vm; 289} 290 291#define CHECK_NON_NULL_ARGUMENT(value) \ 292 CHECK_NON_NULL_ARGUMENT_FN_NAME(__FUNCTION__, value, nullptr) 293 294#define CHECK_NON_NULL_ARGUMENT_RETURN_VOID(value) \ 295 CHECK_NON_NULL_ARGUMENT_FN_NAME(__FUNCTION__, value, ) 296 297#define CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(value) \ 298 CHECK_NON_NULL_ARGUMENT_FN_NAME(__FUNCTION__, value, 0) 299 300#define CHECK_NON_NULL_ARGUMENT_RETURN(value, return_val) \ 301 CHECK_NON_NULL_ARGUMENT_FN_NAME(__FUNCTION__, value, return_val) 302 303#define CHECK_NON_NULL_ARGUMENT_FN_NAME(name, value, return_val) \ 304 if (UNLIKELY(value == nullptr)) { \ 305 JavaVmExtFromEnv(env)->JniAbortF(name, #value " == null"); \ 306 return return_val; \ 307 } 308 309#define CHECK_NON_NULL_MEMCPY_ARGUMENT(length, value) \ 310 if (UNLIKELY(length != 0 && value == nullptr)) { \ 311 JavaVmExtFromEnv(env)->JniAbortF(__FUNCTION__, #value " == null"); \ 312 return; \ 313 } 314 315template <bool kNative> 316static ArtMethod* FindMethod(mirror::Class* c, const StringPiece& name, const StringPiece& sig) 317 SHARED_REQUIRES(Locks::mutator_lock_) { 318 auto pointer_size = Runtime::Current()->GetClassLinker()->GetImagePointerSize(); 319 for (auto& method : c->GetMethods(pointer_size)) { 320 if (kNative == method.IsNative() && name == method.GetName() && method.GetSignature() == sig) { 321 return &method; 322 } 323 } 324 return nullptr; 325} 326 327class JNI { 328 public: 329 static jint GetVersion(JNIEnv*) { 330 return JNI_VERSION_1_6; 331 } 332 333 static jclass DefineClass(JNIEnv*, const char*, jobject, const jbyte*, jsize) { 334 LOG(WARNING) << "JNI DefineClass is not supported"; 335 return nullptr; 336 } 337 338 static jclass FindClass(JNIEnv* env, const char* name) { 339 CHECK_NON_NULL_ARGUMENT(name); 340 Runtime* runtime = Runtime::Current(); 341 ClassLinker* class_linker = runtime->GetClassLinker(); 342 std::string descriptor(NormalizeJniClassDescriptor(name)); 343 ScopedObjectAccess soa(env); 344 mirror::Class* c = nullptr; 345 if (runtime->IsStarted()) { 346 StackHandleScope<1> hs(soa.Self()); 347 Handle<mirror::ClassLoader> class_loader(hs.NewHandle(GetClassLoader(soa))); 348 c = class_linker->FindClass(soa.Self(), descriptor.c_str(), class_loader); 349 } else { 350 c = class_linker->FindSystemClass(soa.Self(), descriptor.c_str()); 351 } 352 return soa.AddLocalReference<jclass>(c); 353 } 354 355 static jmethodID FromReflectedMethod(JNIEnv* env, jobject jlr_method) { 356 CHECK_NON_NULL_ARGUMENT(jlr_method); 357 ScopedObjectAccess soa(env); 358 return soa.EncodeMethod(ArtMethod::FromReflectedMethod(soa, jlr_method)); 359 } 360 361 static jfieldID FromReflectedField(JNIEnv* env, jobject jlr_field) { 362 CHECK_NON_NULL_ARGUMENT(jlr_field); 363 ScopedObjectAccess soa(env); 364 mirror::Object* obj_field = soa.Decode<mirror::Object*>(jlr_field); 365 if (obj_field->GetClass() != mirror::Field::StaticClass()) { 366 // Not even a java.lang.reflect.Field, return null. TODO, is this check necessary? 367 return nullptr; 368 } 369 auto* field = static_cast<mirror::Field*>(obj_field); 370 return soa.EncodeField(field->GetArtField()); 371 } 372 373 static jobject ToReflectedMethod(JNIEnv* env, jclass, jmethodID mid, jboolean) { 374 CHECK_NON_NULL_ARGUMENT(mid); 375 ScopedObjectAccess soa(env); 376 ArtMethod* m = soa.DecodeMethod(mid); 377 mirror::AbstractMethod* method; 378 if (m->IsConstructor()) { 379 method = mirror::Constructor::CreateFromArtMethod(soa.Self(), m); 380 } else { 381 method = mirror::Method::CreateFromArtMethod(soa.Self(), m); 382 } 383 return soa.AddLocalReference<jobject>(method); 384 } 385 386 static jobject ToReflectedField(JNIEnv* env, jclass, jfieldID fid, jboolean) { 387 CHECK_NON_NULL_ARGUMENT(fid); 388 ScopedObjectAccess soa(env); 389 ArtField* f = soa.DecodeField(fid); 390 return soa.AddLocalReference<jobject>(mirror::Field::CreateFromArtField(soa.Self(), f, true)); 391 } 392 393 static jclass GetObjectClass(JNIEnv* env, jobject java_object) { 394 CHECK_NON_NULL_ARGUMENT(java_object); 395 ScopedObjectAccess soa(env); 396 mirror::Object* o = soa.Decode<mirror::Object*>(java_object); 397 return soa.AddLocalReference<jclass>(o->GetClass()); 398 } 399 400 static jclass GetSuperclass(JNIEnv* env, jclass java_class) { 401 CHECK_NON_NULL_ARGUMENT(java_class); 402 ScopedObjectAccess soa(env); 403 mirror::Class* c = soa.Decode<mirror::Class*>(java_class); 404 return soa.AddLocalReference<jclass>(c->IsInterface() ? nullptr : c->GetSuperClass()); 405 } 406 407 // Note: java_class1 should be safely castable to java_class2, and 408 // not the other way around. 409 static jboolean IsAssignableFrom(JNIEnv* env, jclass java_class1, jclass java_class2) { 410 CHECK_NON_NULL_ARGUMENT_RETURN(java_class1, JNI_FALSE); 411 CHECK_NON_NULL_ARGUMENT_RETURN(java_class2, JNI_FALSE); 412 ScopedObjectAccess soa(env); 413 mirror::Class* c1 = soa.Decode<mirror::Class*>(java_class1); 414 mirror::Class* c2 = soa.Decode<mirror::Class*>(java_class2); 415 return c2->IsAssignableFrom(c1) ? JNI_TRUE : JNI_FALSE; 416 } 417 418 static jboolean IsInstanceOf(JNIEnv* env, jobject jobj, jclass java_class) { 419 CHECK_NON_NULL_ARGUMENT_RETURN(java_class, JNI_FALSE); 420 if (jobj == nullptr) { 421 // Note: JNI is different from regular Java instanceof in this respect 422 return JNI_TRUE; 423 } else { 424 ScopedObjectAccess soa(env); 425 mirror::Object* obj = soa.Decode<mirror::Object*>(jobj); 426 mirror::Class* c = soa.Decode<mirror::Class*>(java_class); 427 return obj->InstanceOf(c) ? JNI_TRUE : JNI_FALSE; 428 } 429 } 430 431 static jint Throw(JNIEnv* env, jthrowable java_exception) { 432 ScopedObjectAccess soa(env); 433 mirror::Throwable* exception = soa.Decode<mirror::Throwable*>(java_exception); 434 if (exception == nullptr) { 435 return JNI_ERR; 436 } 437 soa.Self()->SetException(exception); 438 return JNI_OK; 439 } 440 441 static jint ThrowNew(JNIEnv* env, jclass c, const char* msg) { 442 CHECK_NON_NULL_ARGUMENT_RETURN(c, JNI_ERR); 443 return ThrowNewException(env, c, msg, nullptr); 444 } 445 446 static jboolean ExceptionCheck(JNIEnv* env) { 447 return static_cast<JNIEnvExt*>(env)->self->IsExceptionPending() ? JNI_TRUE : JNI_FALSE; 448 } 449 450 static void ExceptionClear(JNIEnv* env) { 451 ScopedObjectAccess soa(env); 452 soa.Self()->ClearException(); 453 } 454 455 static void ExceptionDescribe(JNIEnv* env) { 456 ScopedObjectAccess soa(env); 457 458 // If we have no exception to describe, pass through. 459 if (!soa.Self()->GetException()) { 460 return; 461 } 462 463 StackHandleScope<1> hs(soa.Self()); 464 Handle<mirror::Throwable> old_exception( 465 hs.NewHandle<mirror::Throwable>(soa.Self()->GetException())); 466 soa.Self()->ClearException(); 467 ScopedLocalRef<jthrowable> exception(env, 468 soa.AddLocalReference<jthrowable>(old_exception.Get())); 469 ScopedLocalRef<jclass> exception_class(env, env->GetObjectClass(exception.get())); 470 jmethodID mid = env->GetMethodID(exception_class.get(), "printStackTrace", "()V"); 471 if (mid == nullptr) { 472 LOG(WARNING) << "JNI WARNING: no printStackTrace()V in " 473 << PrettyTypeOf(old_exception.Get()); 474 } else { 475 env->CallVoidMethod(exception.get(), mid); 476 if (soa.Self()->IsExceptionPending()) { 477 LOG(WARNING) << "JNI WARNING: " << PrettyTypeOf(soa.Self()->GetException()) 478 << " thrown while calling printStackTrace"; 479 soa.Self()->ClearException(); 480 } 481 } 482 soa.Self()->SetException(old_exception.Get()); 483 } 484 485 static jthrowable ExceptionOccurred(JNIEnv* env) { 486 ScopedObjectAccess soa(env); 487 mirror::Object* exception = soa.Self()->GetException(); 488 return soa.AddLocalReference<jthrowable>(exception); 489 } 490 491 static void FatalError(JNIEnv*, const char* msg) { 492 LOG(FATAL) << "JNI FatalError called: " << msg; 493 } 494 495 static jint PushLocalFrame(JNIEnv* env, jint capacity) { 496 // TODO: SOA may not be necessary but I do it to please lock annotations. 497 ScopedObjectAccess soa(env); 498 if (EnsureLocalCapacityInternal(soa, capacity, "PushLocalFrame") != JNI_OK) { 499 return JNI_ERR; 500 } 501 down_cast<JNIEnvExt*>(env)->PushFrame(capacity); 502 return JNI_OK; 503 } 504 505 static jobject PopLocalFrame(JNIEnv* env, jobject java_survivor) { 506 ScopedObjectAccess soa(env); 507 mirror::Object* survivor = soa.Decode<mirror::Object*>(java_survivor); 508 soa.Env()->PopFrame(); 509 return soa.AddLocalReference<jobject>(survivor); 510 } 511 512 static jint EnsureLocalCapacity(JNIEnv* env, jint desired_capacity) { 513 // TODO: SOA may not be necessary but I do it to please lock annotations. 514 ScopedObjectAccess soa(env); 515 return EnsureLocalCapacityInternal(soa, desired_capacity, "EnsureLocalCapacity"); 516 } 517 518 static jobject NewGlobalRef(JNIEnv* env, jobject obj) { 519 ScopedObjectAccess soa(env); 520 mirror::Object* decoded_obj = soa.Decode<mirror::Object*>(obj); 521 return soa.Vm()->AddGlobalRef(soa.Self(), decoded_obj); 522 } 523 524 static void DeleteGlobalRef(JNIEnv* env, jobject obj) { 525 JavaVMExt* vm = down_cast<JNIEnvExt*>(env)->vm; 526 Thread* self = down_cast<JNIEnvExt*>(env)->self; 527 vm->DeleteGlobalRef(self, obj); 528 } 529 530 static jweak NewWeakGlobalRef(JNIEnv* env, jobject obj) { 531 ScopedObjectAccess soa(env); 532 mirror::Object* decoded_obj = soa.Decode<mirror::Object*>(obj); 533 return soa.Vm()->AddWeakGlobalRef(soa.Self(), decoded_obj); 534 } 535 536 static void DeleteWeakGlobalRef(JNIEnv* env, jweak obj) { 537 JavaVMExt* vm = down_cast<JNIEnvExt*>(env)->vm; 538 Thread* self = down_cast<JNIEnvExt*>(env)->self; 539 vm->DeleteWeakGlobalRef(self, obj); 540 } 541 542 static jobject NewLocalRef(JNIEnv* env, jobject obj) { 543 ScopedObjectAccess soa(env); 544 mirror::Object* decoded_obj = soa.Decode<mirror::Object*>(obj); 545 // Check for null after decoding the object to handle cleared weak globals. 546 if (decoded_obj == nullptr) { 547 return nullptr; 548 } 549 return soa.AddLocalReference<jobject>(decoded_obj); 550 } 551 552 static void DeleteLocalRef(JNIEnv* env, jobject obj) { 553 if (obj == nullptr) { 554 return; 555 } 556 // SOA is only necessary to have exclusion between GC root marking and removing. 557 // We don't want to have the GC attempt to mark a null root if we just removed 558 // it. b/22119403 559 ScopedObjectAccess soa(env); 560 auto* ext_env = down_cast<JNIEnvExt*>(env); 561 if (!ext_env->locals.Remove(ext_env->local_ref_cookie, obj)) { 562 // Attempting to delete a local reference that is not in the 563 // topmost local reference frame is a no-op. DeleteLocalRef returns 564 // void and doesn't throw any exceptions, but we should probably 565 // complain about it so the user will notice that things aren't 566 // going quite the way they expect. 567 LOG(WARNING) << "JNI WARNING: DeleteLocalRef(" << obj << ") " 568 << "failed to find entry"; 569 } 570 } 571 572 static jboolean IsSameObject(JNIEnv* env, jobject obj1, jobject obj2) { 573 if (obj1 == obj2) { 574 return JNI_TRUE; 575 } else { 576 ScopedObjectAccess soa(env); 577 return (soa.Decode<mirror::Object*>(obj1) == soa.Decode<mirror::Object*>(obj2)) 578 ? JNI_TRUE : JNI_FALSE; 579 } 580 } 581 582 static jobject AllocObject(JNIEnv* env, jclass java_class) { 583 CHECK_NON_NULL_ARGUMENT(java_class); 584 ScopedObjectAccess soa(env); 585 mirror::Class* c = EnsureInitialized(soa.Self(), soa.Decode<mirror::Class*>(java_class)); 586 if (c == nullptr) { 587 return nullptr; 588 } 589 if (c->IsStringClass()) { 590 gc::AllocatorType allocator_type = Runtime::Current()->GetHeap()->GetCurrentAllocator(); 591 mirror::SetStringCountVisitor visitor(0); 592 return soa.AddLocalReference<jobject>(mirror::String::Alloc<true>(soa.Self(), 0, 593 allocator_type, visitor)); 594 } 595 return soa.AddLocalReference<jobject>(c->AllocObject(soa.Self())); 596 } 597 598 static jobject NewObject(JNIEnv* env, jclass java_class, jmethodID mid, ...) { 599 va_list args; 600 va_start(args, mid); 601 CHECK_NON_NULL_ARGUMENT(java_class); 602 CHECK_NON_NULL_ARGUMENT(mid); 603 jobject result = NewObjectV(env, java_class, mid, args); 604 va_end(args); 605 return result; 606 } 607 608 static jobject NewObjectV(JNIEnv* env, jclass java_class, jmethodID mid, va_list args) { 609 CHECK_NON_NULL_ARGUMENT(java_class); 610 CHECK_NON_NULL_ARGUMENT(mid); 611 ScopedObjectAccess soa(env); 612 mirror::Class* c = EnsureInitialized(soa.Self(), soa.Decode<mirror::Class*>(java_class)); 613 if (c == nullptr) { 614 return nullptr; 615 } 616 if (c->IsStringClass()) { 617 // Replace calls to String.<init> with equivalent StringFactory call. 618 jmethodID sf_mid = WellKnownClasses::StringInitToStringFactoryMethodID(mid); 619 return CallStaticObjectMethodV(env, WellKnownClasses::java_lang_StringFactory, sf_mid, args); 620 } 621 mirror::Object* result = c->AllocObject(soa.Self()); 622 if (result == nullptr) { 623 return nullptr; 624 } 625 jobject local_result = soa.AddLocalReference<jobject>(result); 626 CallNonvirtualVoidMethodV(env, local_result, java_class, mid, args); 627 if (soa.Self()->IsExceptionPending()) { 628 return nullptr; 629 } 630 return local_result; 631 } 632 633 static jobject NewObjectA(JNIEnv* env, jclass java_class, jmethodID mid, jvalue* args) { 634 CHECK_NON_NULL_ARGUMENT(java_class); 635 CHECK_NON_NULL_ARGUMENT(mid); 636 ScopedObjectAccess soa(env); 637 mirror::Class* c = EnsureInitialized(soa.Self(), soa.Decode<mirror::Class*>(java_class)); 638 if (c == nullptr) { 639 return nullptr; 640 } 641 if (c->IsStringClass()) { 642 // Replace calls to String.<init> with equivalent StringFactory call. 643 jmethodID sf_mid = WellKnownClasses::StringInitToStringFactoryMethodID(mid); 644 return CallStaticObjectMethodA(env, WellKnownClasses::java_lang_StringFactory, sf_mid, args); 645 } 646 mirror::Object* result = c->AllocObject(soa.Self()); 647 if (result == nullptr) { 648 return nullptr; 649 } 650 jobject local_result = soa.AddLocalReference<jobjectArray>(result); 651 CallNonvirtualVoidMethodA(env, local_result, java_class, mid, args); 652 if (soa.Self()->IsExceptionPending()) { 653 return nullptr; 654 } 655 return local_result; 656 } 657 658 static jmethodID GetMethodID(JNIEnv* env, jclass java_class, const char* name, const char* sig) { 659 CHECK_NON_NULL_ARGUMENT(java_class); 660 CHECK_NON_NULL_ARGUMENT(name); 661 CHECK_NON_NULL_ARGUMENT(sig); 662 ScopedObjectAccess soa(env); 663 return FindMethodID(soa, java_class, name, sig, false); 664 } 665 666 static jmethodID GetStaticMethodID(JNIEnv* env, jclass java_class, const char* name, 667 const char* sig) { 668 CHECK_NON_NULL_ARGUMENT(java_class); 669 CHECK_NON_NULL_ARGUMENT(name); 670 CHECK_NON_NULL_ARGUMENT(sig); 671 ScopedObjectAccess soa(env); 672 return FindMethodID(soa, java_class, name, sig, true); 673 } 674 675 static jobject CallObjectMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 676 va_list ap; 677 va_start(ap, mid); 678 CHECK_NON_NULL_ARGUMENT(obj); 679 CHECK_NON_NULL_ARGUMENT(mid); 680 ScopedObjectAccess soa(env); 681 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 682 va_end(ap); 683 return soa.AddLocalReference<jobject>(result.GetL()); 684 } 685 686 static jobject CallObjectMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 687 CHECK_NON_NULL_ARGUMENT(obj); 688 CHECK_NON_NULL_ARGUMENT(mid); 689 ScopedObjectAccess soa(env); 690 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args)); 691 return soa.AddLocalReference<jobject>(result.GetL()); 692 } 693 694 static jobject CallObjectMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 695 CHECK_NON_NULL_ARGUMENT(obj); 696 CHECK_NON_NULL_ARGUMENT(mid); 697 ScopedObjectAccess soa(env); 698 JValue result(InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args)); 699 return soa.AddLocalReference<jobject>(result.GetL()); 700 } 701 702 static jboolean CallBooleanMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 703 va_list ap; 704 va_start(ap, mid); 705 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 706 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 707 ScopedObjectAccess soa(env); 708 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 709 va_end(ap); 710 return result.GetZ(); 711 } 712 713 static jboolean CallBooleanMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 714 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 715 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 716 ScopedObjectAccess soa(env); 717 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetZ(); 718 } 719 720 static jboolean CallBooleanMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 721 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 722 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 723 ScopedObjectAccess soa(env); 724 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetZ(); 725 } 726 727 static jbyte CallByteMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 728 va_list ap; 729 va_start(ap, mid); 730 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 731 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 732 ScopedObjectAccess soa(env); 733 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 734 va_end(ap); 735 return result.GetB(); 736 } 737 738 static jbyte CallByteMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 739 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 740 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 741 ScopedObjectAccess soa(env); 742 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetB(); 743 } 744 745 static jbyte CallByteMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 746 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 747 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 748 ScopedObjectAccess soa(env); 749 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetB(); 750 } 751 752 static jchar CallCharMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 753 va_list ap; 754 va_start(ap, mid); 755 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 756 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 757 ScopedObjectAccess soa(env); 758 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 759 va_end(ap); 760 return result.GetC(); 761 } 762 763 static jchar CallCharMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 764 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 765 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 766 ScopedObjectAccess soa(env); 767 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetC(); 768 } 769 770 static jchar CallCharMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 771 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 772 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 773 ScopedObjectAccess soa(env); 774 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetC(); 775 } 776 777 static jdouble CallDoubleMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 778 va_list ap; 779 va_start(ap, mid); 780 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 781 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 782 ScopedObjectAccess soa(env); 783 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 784 va_end(ap); 785 return result.GetD(); 786 } 787 788 static jdouble CallDoubleMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 789 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 790 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 791 ScopedObjectAccess soa(env); 792 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetD(); 793 } 794 795 static jdouble CallDoubleMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 796 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 797 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 798 ScopedObjectAccess soa(env); 799 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetD(); 800 } 801 802 static jfloat CallFloatMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 803 va_list ap; 804 va_start(ap, mid); 805 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 806 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 807 ScopedObjectAccess soa(env); 808 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 809 va_end(ap); 810 return result.GetF(); 811 } 812 813 static jfloat CallFloatMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 814 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 815 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 816 ScopedObjectAccess soa(env); 817 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetF(); 818 } 819 820 static jfloat CallFloatMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 821 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 822 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 823 ScopedObjectAccess soa(env); 824 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetF(); 825 } 826 827 static jint CallIntMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 828 va_list ap; 829 va_start(ap, mid); 830 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 831 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 832 ScopedObjectAccess soa(env); 833 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 834 va_end(ap); 835 return result.GetI(); 836 } 837 838 static jint CallIntMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 839 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 840 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 841 ScopedObjectAccess soa(env); 842 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetI(); 843 } 844 845 static jint CallIntMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 846 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 847 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 848 ScopedObjectAccess soa(env); 849 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetI(); 850 } 851 852 static jlong CallLongMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 853 va_list ap; 854 va_start(ap, mid); 855 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 856 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 857 ScopedObjectAccess soa(env); 858 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 859 va_end(ap); 860 return result.GetJ(); 861 } 862 863 static jlong CallLongMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 864 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 865 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 866 ScopedObjectAccess soa(env); 867 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetJ(); 868 } 869 870 static jlong CallLongMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 871 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 872 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 873 ScopedObjectAccess soa(env); 874 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetJ(); 875 } 876 877 static jshort CallShortMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 878 va_list ap; 879 va_start(ap, mid); 880 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 881 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 882 ScopedObjectAccess soa(env); 883 JValue result(InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap)); 884 va_end(ap); 885 return result.GetS(); 886 } 887 888 static jshort CallShortMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 889 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 890 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 891 ScopedObjectAccess soa(env); 892 return InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args).GetS(); 893 } 894 895 static jshort CallShortMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 896 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 897 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 898 ScopedObjectAccess soa(env); 899 return InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args).GetS(); 900 } 901 902 static void CallVoidMethod(JNIEnv* env, jobject obj, jmethodID mid, ...) { 903 va_list ap; 904 va_start(ap, mid); 905 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(obj); 906 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 907 ScopedObjectAccess soa(env); 908 InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, ap); 909 va_end(ap); 910 } 911 912 static void CallVoidMethodV(JNIEnv* env, jobject obj, jmethodID mid, va_list args) { 913 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(obj); 914 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 915 ScopedObjectAccess soa(env); 916 InvokeVirtualOrInterfaceWithVarArgs(soa, obj, mid, args); 917 } 918 919 static void CallVoidMethodA(JNIEnv* env, jobject obj, jmethodID mid, jvalue* args) { 920 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(obj); 921 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 922 ScopedObjectAccess soa(env); 923 InvokeVirtualOrInterfaceWithJValues(soa, obj, mid, args); 924 } 925 926 static jobject CallNonvirtualObjectMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 927 va_list ap; 928 va_start(ap, mid); 929 CHECK_NON_NULL_ARGUMENT(obj); 930 CHECK_NON_NULL_ARGUMENT(mid); 931 ScopedObjectAccess soa(env); 932 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 933 jobject local_result = soa.AddLocalReference<jobject>(result.GetL()); 934 va_end(ap); 935 return local_result; 936 } 937 938 static jobject CallNonvirtualObjectMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 939 va_list args) { 940 CHECK_NON_NULL_ARGUMENT(obj); 941 CHECK_NON_NULL_ARGUMENT(mid); 942 ScopedObjectAccess soa(env); 943 JValue result(InvokeWithVarArgs(soa, obj, mid, args)); 944 return soa.AddLocalReference<jobject>(result.GetL()); 945 } 946 947 static jobject CallNonvirtualObjectMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 948 jvalue* args) { 949 CHECK_NON_NULL_ARGUMENT(obj); 950 CHECK_NON_NULL_ARGUMENT(mid); 951 ScopedObjectAccess soa(env); 952 JValue result(InvokeWithJValues(soa, obj, mid, args)); 953 return soa.AddLocalReference<jobject>(result.GetL()); 954 } 955 956 static jboolean CallNonvirtualBooleanMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, 957 ...) { 958 va_list ap; 959 va_start(ap, mid); 960 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 961 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 962 ScopedObjectAccess soa(env); 963 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 964 va_end(ap); 965 return result.GetZ(); 966 } 967 968 static jboolean CallNonvirtualBooleanMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 969 va_list args) { 970 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 971 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 972 ScopedObjectAccess soa(env); 973 return InvokeWithVarArgs(soa, obj, mid, args).GetZ(); 974 } 975 976 static jboolean CallNonvirtualBooleanMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 977 jvalue* args) { 978 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 979 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 980 ScopedObjectAccess soa(env); 981 return InvokeWithJValues(soa, obj, mid, args).GetZ(); 982 } 983 984 static jbyte CallNonvirtualByteMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 985 va_list ap; 986 va_start(ap, mid); 987 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 988 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 989 ScopedObjectAccess soa(env); 990 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 991 va_end(ap); 992 return result.GetB(); 993 } 994 995 static jbyte CallNonvirtualByteMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 996 va_list args) { 997 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 998 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 999 ScopedObjectAccess soa(env); 1000 return InvokeWithVarArgs(soa, obj, mid, args).GetB(); 1001 } 1002 1003 static jbyte CallNonvirtualByteMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1004 jvalue* args) { 1005 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1006 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1007 ScopedObjectAccess soa(env); 1008 return InvokeWithJValues(soa, obj, mid, args).GetB(); 1009 } 1010 1011 static jchar CallNonvirtualCharMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 1012 va_list ap; 1013 va_start(ap, mid); 1014 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1015 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1016 ScopedObjectAccess soa(env); 1017 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 1018 va_end(ap); 1019 return result.GetC(); 1020 } 1021 1022 static jchar CallNonvirtualCharMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1023 va_list args) { 1024 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1025 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1026 ScopedObjectAccess soa(env); 1027 return InvokeWithVarArgs(soa, obj, mid, args).GetC(); 1028 } 1029 1030 static jchar CallNonvirtualCharMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1031 jvalue* args) { 1032 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1033 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1034 ScopedObjectAccess soa(env); 1035 return InvokeWithJValues(soa, obj, mid, args).GetC(); 1036 } 1037 1038 static jshort CallNonvirtualShortMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 1039 va_list ap; 1040 va_start(ap, mid); 1041 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1042 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1043 ScopedObjectAccess soa(env); 1044 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 1045 va_end(ap); 1046 return result.GetS(); 1047 } 1048 1049 static jshort CallNonvirtualShortMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1050 va_list args) { 1051 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1052 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1053 ScopedObjectAccess soa(env); 1054 return InvokeWithVarArgs(soa, obj, mid, args).GetS(); 1055 } 1056 1057 static jshort CallNonvirtualShortMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1058 jvalue* args) { 1059 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1060 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1061 ScopedObjectAccess soa(env); 1062 return InvokeWithJValues(soa, obj, mid, args).GetS(); 1063 } 1064 1065 static jint CallNonvirtualIntMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 1066 va_list ap; 1067 va_start(ap, mid); 1068 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1069 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1070 ScopedObjectAccess soa(env); 1071 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 1072 va_end(ap); 1073 return result.GetI(); 1074 } 1075 1076 static jint CallNonvirtualIntMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1077 va_list args) { 1078 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1079 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1080 ScopedObjectAccess soa(env); 1081 return InvokeWithVarArgs(soa, obj, mid, args).GetI(); 1082 } 1083 1084 static jint CallNonvirtualIntMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1085 jvalue* args) { 1086 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1087 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1088 ScopedObjectAccess soa(env); 1089 return InvokeWithJValues(soa, obj, mid, args).GetI(); 1090 } 1091 1092 static jlong CallNonvirtualLongMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 1093 va_list ap; 1094 va_start(ap, mid); 1095 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1096 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1097 ScopedObjectAccess soa(env); 1098 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 1099 va_end(ap); 1100 return result.GetJ(); 1101 } 1102 1103 static jlong CallNonvirtualLongMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1104 va_list args) { 1105 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1106 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1107 ScopedObjectAccess soa(env); 1108 return InvokeWithVarArgs(soa, obj, mid, args).GetJ(); 1109 } 1110 1111 static jlong CallNonvirtualLongMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1112 jvalue* args) { 1113 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1114 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1115 ScopedObjectAccess soa(env); 1116 return InvokeWithJValues(soa, obj, mid, args).GetJ(); 1117 } 1118 1119 static jfloat CallNonvirtualFloatMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 1120 va_list ap; 1121 va_start(ap, mid); 1122 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1123 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1124 ScopedObjectAccess soa(env); 1125 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 1126 va_end(ap); 1127 return result.GetF(); 1128 } 1129 1130 static jfloat CallNonvirtualFloatMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1131 va_list args) { 1132 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1133 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1134 ScopedObjectAccess soa(env); 1135 return InvokeWithVarArgs(soa, obj, mid, args).GetF(); 1136 } 1137 1138 static jfloat CallNonvirtualFloatMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1139 jvalue* args) { 1140 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1141 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1142 ScopedObjectAccess soa(env); 1143 return InvokeWithJValues(soa, obj, mid, args).GetF(); 1144 } 1145 1146 static jdouble CallNonvirtualDoubleMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 1147 va_list ap; 1148 va_start(ap, mid); 1149 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1150 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1151 ScopedObjectAccess soa(env); 1152 JValue result(InvokeWithVarArgs(soa, obj, mid, ap)); 1153 va_end(ap); 1154 return result.GetD(); 1155 } 1156 1157 static jdouble CallNonvirtualDoubleMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1158 va_list args) { 1159 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1160 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1161 ScopedObjectAccess soa(env); 1162 return InvokeWithVarArgs(soa, obj, mid, args).GetD(); 1163 } 1164 1165 static jdouble CallNonvirtualDoubleMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1166 jvalue* args) { 1167 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(obj); 1168 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1169 ScopedObjectAccess soa(env); 1170 return InvokeWithJValues(soa, obj, mid, args).GetD(); 1171 } 1172 1173 static void CallNonvirtualVoidMethod(JNIEnv* env, jobject obj, jclass, jmethodID mid, ...) { 1174 va_list ap; 1175 va_start(ap, mid); 1176 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(obj); 1177 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 1178 ScopedObjectAccess soa(env); 1179 InvokeWithVarArgs(soa, obj, mid, ap); 1180 va_end(ap); 1181 } 1182 1183 static void CallNonvirtualVoidMethodV(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1184 va_list args) { 1185 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(obj); 1186 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 1187 ScopedObjectAccess soa(env); 1188 InvokeWithVarArgs(soa, obj, mid, args); 1189 } 1190 1191 static void CallNonvirtualVoidMethodA(JNIEnv* env, jobject obj, jclass, jmethodID mid, 1192 jvalue* args) { 1193 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(obj); 1194 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 1195 ScopedObjectAccess soa(env); 1196 InvokeWithJValues(soa, obj, mid, args); 1197 } 1198 1199 static jfieldID GetFieldID(JNIEnv* env, jclass java_class, const char* name, const char* sig) { 1200 CHECK_NON_NULL_ARGUMENT(java_class); 1201 CHECK_NON_NULL_ARGUMENT(name); 1202 CHECK_NON_NULL_ARGUMENT(sig); 1203 ScopedObjectAccess soa(env); 1204 return FindFieldID(soa, java_class, name, sig, false); 1205 } 1206 1207 static jfieldID GetStaticFieldID(JNIEnv* env, jclass java_class, const char* name, 1208 const char* sig) { 1209 CHECK_NON_NULL_ARGUMENT(java_class); 1210 CHECK_NON_NULL_ARGUMENT(name); 1211 CHECK_NON_NULL_ARGUMENT(sig); 1212 ScopedObjectAccess soa(env); 1213 return FindFieldID(soa, java_class, name, sig, true); 1214 } 1215 1216 static jobject GetObjectField(JNIEnv* env, jobject obj, jfieldID fid) { 1217 CHECK_NON_NULL_ARGUMENT(obj); 1218 CHECK_NON_NULL_ARGUMENT(fid); 1219 ScopedObjectAccess soa(env); 1220 mirror::Object* o = soa.Decode<mirror::Object*>(obj); 1221 ArtField* f = soa.DecodeField(fid); 1222 return soa.AddLocalReference<jobject>(f->GetObject(o)); 1223 } 1224 1225 static jobject GetStaticObjectField(JNIEnv* env, jclass, jfieldID fid) { 1226 CHECK_NON_NULL_ARGUMENT(fid); 1227 ScopedObjectAccess soa(env); 1228 ArtField* f = soa.DecodeField(fid); 1229 return soa.AddLocalReference<jobject>(f->GetObject(f->GetDeclaringClass())); 1230 } 1231 1232 static void SetObjectField(JNIEnv* env, jobject java_object, jfieldID fid, jobject java_value) { 1233 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_object); 1234 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(fid); 1235 ScopedObjectAccess soa(env); 1236 mirror::Object* o = soa.Decode<mirror::Object*>(java_object); 1237 mirror::Object* v = soa.Decode<mirror::Object*>(java_value); 1238 ArtField* f = soa.DecodeField(fid); 1239 f->SetObject<false>(o, v); 1240 } 1241 1242 static void SetStaticObjectField(JNIEnv* env, jclass, jfieldID fid, jobject java_value) { 1243 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(fid); 1244 ScopedObjectAccess soa(env); 1245 mirror::Object* v = soa.Decode<mirror::Object*>(java_value); 1246 ArtField* f = soa.DecodeField(fid); 1247 f->SetObject<false>(f->GetDeclaringClass(), v); 1248 } 1249 1250#define GET_PRIMITIVE_FIELD(fn, instance) \ 1251 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(instance); \ 1252 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(fid); \ 1253 ScopedObjectAccess soa(env); \ 1254 mirror::Object* o = soa.Decode<mirror::Object*>(instance); \ 1255 ArtField* f = soa.DecodeField(fid); \ 1256 return f->Get ##fn (o) 1257 1258#define GET_STATIC_PRIMITIVE_FIELD(fn) \ 1259 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(fid); \ 1260 ScopedObjectAccess soa(env); \ 1261 ArtField* f = soa.DecodeField(fid); \ 1262 return f->Get ##fn (f->GetDeclaringClass()) 1263 1264#define SET_PRIMITIVE_FIELD(fn, instance, value) \ 1265 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(instance); \ 1266 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(fid); \ 1267 ScopedObjectAccess soa(env); \ 1268 mirror::Object* o = soa.Decode<mirror::Object*>(instance); \ 1269 ArtField* f = soa.DecodeField(fid); \ 1270 f->Set ##fn <false>(o, value) 1271 1272#define SET_STATIC_PRIMITIVE_FIELD(fn, value) \ 1273 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(fid); \ 1274 ScopedObjectAccess soa(env); \ 1275 ArtField* f = soa.DecodeField(fid); \ 1276 f->Set ##fn <false>(f->GetDeclaringClass(), value) 1277 1278 static jboolean GetBooleanField(JNIEnv* env, jobject obj, jfieldID fid) { 1279 GET_PRIMITIVE_FIELD(Boolean, obj); 1280 } 1281 1282 static jbyte GetByteField(JNIEnv* env, jobject obj, jfieldID fid) { 1283 GET_PRIMITIVE_FIELD(Byte, obj); 1284 } 1285 1286 static jchar GetCharField(JNIEnv* env, jobject obj, jfieldID fid) { 1287 GET_PRIMITIVE_FIELD(Char, obj); 1288 } 1289 1290 static jshort GetShortField(JNIEnv* env, jobject obj, jfieldID fid) { 1291 GET_PRIMITIVE_FIELD(Short, obj); 1292 } 1293 1294 static jint GetIntField(JNIEnv* env, jobject obj, jfieldID fid) { 1295 GET_PRIMITIVE_FIELD(Int, obj); 1296 } 1297 1298 static jlong GetLongField(JNIEnv* env, jobject obj, jfieldID fid) { 1299 GET_PRIMITIVE_FIELD(Long, obj); 1300 } 1301 1302 static jfloat GetFloatField(JNIEnv* env, jobject obj, jfieldID fid) { 1303 GET_PRIMITIVE_FIELD(Float, obj); 1304 } 1305 1306 static jdouble GetDoubleField(JNIEnv* env, jobject obj, jfieldID fid) { 1307 GET_PRIMITIVE_FIELD(Double, obj); 1308 } 1309 1310 static jboolean GetStaticBooleanField(JNIEnv* env, jclass, jfieldID fid) { 1311 GET_STATIC_PRIMITIVE_FIELD(Boolean); 1312 } 1313 1314 static jbyte GetStaticByteField(JNIEnv* env, jclass, jfieldID fid) { 1315 GET_STATIC_PRIMITIVE_FIELD(Byte); 1316 } 1317 1318 static jchar GetStaticCharField(JNIEnv* env, jclass, jfieldID fid) { 1319 GET_STATIC_PRIMITIVE_FIELD(Char); 1320 } 1321 1322 static jshort GetStaticShortField(JNIEnv* env, jclass, jfieldID fid) { 1323 GET_STATIC_PRIMITIVE_FIELD(Short); 1324 } 1325 1326 static jint GetStaticIntField(JNIEnv* env, jclass, jfieldID fid) { 1327 GET_STATIC_PRIMITIVE_FIELD(Int); 1328 } 1329 1330 static jlong GetStaticLongField(JNIEnv* env, jclass, jfieldID fid) { 1331 GET_STATIC_PRIMITIVE_FIELD(Long); 1332 } 1333 1334 static jfloat GetStaticFloatField(JNIEnv* env, jclass, jfieldID fid) { 1335 GET_STATIC_PRIMITIVE_FIELD(Float); 1336 } 1337 1338 static jdouble GetStaticDoubleField(JNIEnv* env, jclass, jfieldID fid) { 1339 GET_STATIC_PRIMITIVE_FIELD(Double); 1340 } 1341 1342 static void SetBooleanField(JNIEnv* env, jobject obj, jfieldID fid, jboolean v) { 1343 SET_PRIMITIVE_FIELD(Boolean, obj, v); 1344 } 1345 1346 static void SetByteField(JNIEnv* env, jobject obj, jfieldID fid, jbyte v) { 1347 SET_PRIMITIVE_FIELD(Byte, obj, v); 1348 } 1349 1350 static void SetCharField(JNIEnv* env, jobject obj, jfieldID fid, jchar v) { 1351 SET_PRIMITIVE_FIELD(Char, obj, v); 1352 } 1353 1354 static void SetFloatField(JNIEnv* env, jobject obj, jfieldID fid, jfloat v) { 1355 SET_PRIMITIVE_FIELD(Float, obj, v); 1356 } 1357 1358 static void SetDoubleField(JNIEnv* env, jobject obj, jfieldID fid, jdouble v) { 1359 SET_PRIMITIVE_FIELD(Double, obj, v); 1360 } 1361 1362 static void SetIntField(JNIEnv* env, jobject obj, jfieldID fid, jint v) { 1363 SET_PRIMITIVE_FIELD(Int, obj, v); 1364 } 1365 1366 static void SetLongField(JNIEnv* env, jobject obj, jfieldID fid, jlong v) { 1367 SET_PRIMITIVE_FIELD(Long, obj, v); 1368 } 1369 1370 static void SetShortField(JNIEnv* env, jobject obj, jfieldID fid, jshort v) { 1371 SET_PRIMITIVE_FIELD(Short, obj, v); 1372 } 1373 1374 static void SetStaticBooleanField(JNIEnv* env, jclass, jfieldID fid, jboolean v) { 1375 SET_STATIC_PRIMITIVE_FIELD(Boolean, v); 1376 } 1377 1378 static void SetStaticByteField(JNIEnv* env, jclass, jfieldID fid, jbyte v) { 1379 SET_STATIC_PRIMITIVE_FIELD(Byte, v); 1380 } 1381 1382 static void SetStaticCharField(JNIEnv* env, jclass, jfieldID fid, jchar v) { 1383 SET_STATIC_PRIMITIVE_FIELD(Char, v); 1384 } 1385 1386 static void SetStaticFloatField(JNIEnv* env, jclass, jfieldID fid, jfloat v) { 1387 SET_STATIC_PRIMITIVE_FIELD(Float, v); 1388 } 1389 1390 static void SetStaticDoubleField(JNIEnv* env, jclass, jfieldID fid, jdouble v) { 1391 SET_STATIC_PRIMITIVE_FIELD(Double, v); 1392 } 1393 1394 static void SetStaticIntField(JNIEnv* env, jclass, jfieldID fid, jint v) { 1395 SET_STATIC_PRIMITIVE_FIELD(Int, v); 1396 } 1397 1398 static void SetStaticLongField(JNIEnv* env, jclass, jfieldID fid, jlong v) { 1399 SET_STATIC_PRIMITIVE_FIELD(Long, v); 1400 } 1401 1402 static void SetStaticShortField(JNIEnv* env, jclass, jfieldID fid, jshort v) { 1403 SET_STATIC_PRIMITIVE_FIELD(Short, v); 1404 } 1405 1406 static jobject CallStaticObjectMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1407 va_list ap; 1408 va_start(ap, mid); 1409 CHECK_NON_NULL_ARGUMENT(mid); 1410 ScopedObjectAccess soa(env); 1411 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1412 jobject local_result = soa.AddLocalReference<jobject>(result.GetL()); 1413 va_end(ap); 1414 return local_result; 1415 } 1416 1417 static jobject CallStaticObjectMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1418 CHECK_NON_NULL_ARGUMENT(mid); 1419 ScopedObjectAccess soa(env); 1420 JValue result(InvokeWithVarArgs(soa, nullptr, mid, args)); 1421 return soa.AddLocalReference<jobject>(result.GetL()); 1422 } 1423 1424 static jobject CallStaticObjectMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1425 CHECK_NON_NULL_ARGUMENT(mid); 1426 ScopedObjectAccess soa(env); 1427 JValue result(InvokeWithJValues(soa, nullptr, mid, args)); 1428 return soa.AddLocalReference<jobject>(result.GetL()); 1429 } 1430 1431 static jboolean CallStaticBooleanMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1432 va_list ap; 1433 va_start(ap, mid); 1434 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1435 ScopedObjectAccess soa(env); 1436 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1437 va_end(ap); 1438 return result.GetZ(); 1439 } 1440 1441 static jboolean CallStaticBooleanMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1442 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1443 ScopedObjectAccess soa(env); 1444 return InvokeWithVarArgs(soa, nullptr, mid, args).GetZ(); 1445 } 1446 1447 static jboolean CallStaticBooleanMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1448 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1449 ScopedObjectAccess soa(env); 1450 return InvokeWithJValues(soa, nullptr, mid, args).GetZ(); 1451 } 1452 1453 static jbyte CallStaticByteMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1454 va_list ap; 1455 va_start(ap, mid); 1456 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1457 ScopedObjectAccess soa(env); 1458 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1459 va_end(ap); 1460 return result.GetB(); 1461 } 1462 1463 static jbyte CallStaticByteMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1464 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1465 ScopedObjectAccess soa(env); 1466 return InvokeWithVarArgs(soa, nullptr, mid, args).GetB(); 1467 } 1468 1469 static jbyte CallStaticByteMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1470 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1471 ScopedObjectAccess soa(env); 1472 return InvokeWithJValues(soa, nullptr, mid, args).GetB(); 1473 } 1474 1475 static jchar CallStaticCharMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1476 va_list ap; 1477 va_start(ap, mid); 1478 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1479 ScopedObjectAccess soa(env); 1480 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1481 va_end(ap); 1482 return result.GetC(); 1483 } 1484 1485 static jchar CallStaticCharMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1486 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1487 ScopedObjectAccess soa(env); 1488 return InvokeWithVarArgs(soa, nullptr, mid, args).GetC(); 1489 } 1490 1491 static jchar CallStaticCharMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1492 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1493 ScopedObjectAccess soa(env); 1494 return InvokeWithJValues(soa, nullptr, mid, args).GetC(); 1495 } 1496 1497 static jshort CallStaticShortMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1498 va_list ap; 1499 va_start(ap, mid); 1500 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1501 ScopedObjectAccess soa(env); 1502 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1503 va_end(ap); 1504 return result.GetS(); 1505 } 1506 1507 static jshort CallStaticShortMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1508 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1509 ScopedObjectAccess soa(env); 1510 return InvokeWithVarArgs(soa, nullptr, mid, args).GetS(); 1511 } 1512 1513 static jshort CallStaticShortMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1514 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1515 ScopedObjectAccess soa(env); 1516 return InvokeWithJValues(soa, nullptr, mid, args).GetS(); 1517 } 1518 1519 static jint CallStaticIntMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1520 va_list ap; 1521 va_start(ap, mid); 1522 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1523 ScopedObjectAccess soa(env); 1524 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1525 va_end(ap); 1526 return result.GetI(); 1527 } 1528 1529 static jint CallStaticIntMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1530 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1531 ScopedObjectAccess soa(env); 1532 return InvokeWithVarArgs(soa, nullptr, mid, args).GetI(); 1533 } 1534 1535 static jint CallStaticIntMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1536 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1537 ScopedObjectAccess soa(env); 1538 return InvokeWithJValues(soa, nullptr, mid, args).GetI(); 1539 } 1540 1541 static jlong CallStaticLongMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1542 va_list ap; 1543 va_start(ap, mid); 1544 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1545 ScopedObjectAccess soa(env); 1546 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1547 va_end(ap); 1548 return result.GetJ(); 1549 } 1550 1551 static jlong CallStaticLongMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1552 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1553 ScopedObjectAccess soa(env); 1554 return InvokeWithVarArgs(soa, nullptr, mid, args).GetJ(); 1555 } 1556 1557 static jlong CallStaticLongMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1558 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1559 ScopedObjectAccess soa(env); 1560 return InvokeWithJValues(soa, nullptr, mid, args).GetJ(); 1561 } 1562 1563 static jfloat CallStaticFloatMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1564 va_list ap; 1565 va_start(ap, mid); 1566 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1567 ScopedObjectAccess soa(env); 1568 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1569 va_end(ap); 1570 return result.GetF(); 1571 } 1572 1573 static jfloat CallStaticFloatMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1574 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1575 ScopedObjectAccess soa(env); 1576 return InvokeWithVarArgs(soa, nullptr, mid, args).GetF(); 1577 } 1578 1579 static jfloat CallStaticFloatMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1580 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1581 ScopedObjectAccess soa(env); 1582 return InvokeWithJValues(soa, nullptr, mid, args).GetF(); 1583 } 1584 1585 static jdouble CallStaticDoubleMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1586 va_list ap; 1587 va_start(ap, mid); 1588 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1589 ScopedObjectAccess soa(env); 1590 JValue result(InvokeWithVarArgs(soa, nullptr, mid, ap)); 1591 va_end(ap); 1592 return result.GetD(); 1593 } 1594 1595 static jdouble CallStaticDoubleMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1596 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1597 ScopedObjectAccess soa(env); 1598 return InvokeWithVarArgs(soa, nullptr, mid, args).GetD(); 1599 } 1600 1601 static jdouble CallStaticDoubleMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1602 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(mid); 1603 ScopedObjectAccess soa(env); 1604 return InvokeWithJValues(soa, nullptr, mid, args).GetD(); 1605 } 1606 1607 static void CallStaticVoidMethod(JNIEnv* env, jclass, jmethodID mid, ...) { 1608 va_list ap; 1609 va_start(ap, mid); 1610 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 1611 ScopedObjectAccess soa(env); 1612 InvokeWithVarArgs(soa, nullptr, mid, ap); 1613 va_end(ap); 1614 } 1615 1616 static void CallStaticVoidMethodV(JNIEnv* env, jclass, jmethodID mid, va_list args) { 1617 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 1618 ScopedObjectAccess soa(env); 1619 InvokeWithVarArgs(soa, nullptr, mid, args); 1620 } 1621 1622 static void CallStaticVoidMethodA(JNIEnv* env, jclass, jmethodID mid, jvalue* args) { 1623 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(mid); 1624 ScopedObjectAccess soa(env); 1625 InvokeWithJValues(soa, nullptr, mid, args); 1626 } 1627 1628 static jstring NewString(JNIEnv* env, const jchar* chars, jsize char_count) { 1629 if (UNLIKELY(char_count < 0)) { 1630 JavaVmExtFromEnv(env)->JniAbortF("NewString", "char_count < 0: %d", char_count); 1631 return nullptr; 1632 } 1633 if (UNLIKELY(chars == nullptr && char_count > 0)) { 1634 JavaVmExtFromEnv(env)->JniAbortF("NewString", "chars == null && char_count > 0"); 1635 return nullptr; 1636 } 1637 ScopedObjectAccess soa(env); 1638 mirror::String* result = mirror::String::AllocFromUtf16(soa.Self(), char_count, chars); 1639 return soa.AddLocalReference<jstring>(result); 1640 } 1641 1642 static jstring NewStringUTF(JNIEnv* env, const char* utf) { 1643 if (utf == nullptr) { 1644 return nullptr; 1645 } 1646 ScopedObjectAccess soa(env); 1647 mirror::String* result = mirror::String::AllocFromModifiedUtf8(soa.Self(), utf); 1648 return soa.AddLocalReference<jstring>(result); 1649 } 1650 1651 static jsize GetStringLength(JNIEnv* env, jstring java_string) { 1652 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(java_string); 1653 ScopedObjectAccess soa(env); 1654 return soa.Decode<mirror::String*>(java_string)->GetLength(); 1655 } 1656 1657 static jsize GetStringUTFLength(JNIEnv* env, jstring java_string) { 1658 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(java_string); 1659 ScopedObjectAccess soa(env); 1660 return soa.Decode<mirror::String*>(java_string)->GetUtfLength(); 1661 } 1662 1663 static void GetStringRegion(JNIEnv* env, jstring java_string, jsize start, jsize length, 1664 jchar* buf) { 1665 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_string); 1666 ScopedObjectAccess soa(env); 1667 mirror::String* s = soa.Decode<mirror::String*>(java_string); 1668 if (start < 0 || length < 0 || length > s->GetLength() - start) { 1669 ThrowSIOOBE(soa, start, length, s->GetLength()); 1670 } else { 1671 CHECK_NON_NULL_MEMCPY_ARGUMENT(length, buf); 1672 const jchar* chars = s->GetValue(); 1673 memcpy(buf, chars + start, length * sizeof(jchar)); 1674 } 1675 } 1676 1677 static void GetStringUTFRegion(JNIEnv* env, jstring java_string, jsize start, jsize length, 1678 char* buf) { 1679 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_string); 1680 ScopedObjectAccess soa(env); 1681 mirror::String* s = soa.Decode<mirror::String*>(java_string); 1682 if (start < 0 || length < 0 || length > s->GetLength() - start) { 1683 ThrowSIOOBE(soa, start, length, s->GetLength()); 1684 } else { 1685 CHECK_NON_NULL_MEMCPY_ARGUMENT(length, buf); 1686 const jchar* chars = s->GetValue(); 1687 size_t bytes = CountUtf8Bytes(chars + start, length); 1688 ConvertUtf16ToModifiedUtf8(buf, bytes, chars + start, length); 1689 } 1690 } 1691 1692 static const jchar* GetStringChars(JNIEnv* env, jstring java_string, jboolean* is_copy) { 1693 CHECK_NON_NULL_ARGUMENT(java_string); 1694 ScopedObjectAccess soa(env); 1695 mirror::String* s = soa.Decode<mirror::String*>(java_string); 1696 gc::Heap* heap = Runtime::Current()->GetHeap(); 1697 if (heap->IsMovableObject(s)) { 1698 jchar* chars = new jchar[s->GetLength()]; 1699 memcpy(chars, s->GetValue(), sizeof(jchar) * s->GetLength()); 1700 if (is_copy != nullptr) { 1701 *is_copy = JNI_TRUE; 1702 } 1703 return chars; 1704 } 1705 if (is_copy != nullptr) { 1706 *is_copy = JNI_FALSE; 1707 } 1708 return static_cast<jchar*>(s->GetValue()); 1709 } 1710 1711 static void ReleaseStringChars(JNIEnv* env, jstring java_string, const jchar* chars) { 1712 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_string); 1713 ScopedObjectAccess soa(env); 1714 mirror::String* s = soa.Decode<mirror::String*>(java_string); 1715 if (chars != s->GetValue()) { 1716 delete[] chars; 1717 } 1718 } 1719 1720 static const jchar* GetStringCritical(JNIEnv* env, jstring java_string, jboolean* is_copy) { 1721 CHECK_NON_NULL_ARGUMENT(java_string); 1722 ScopedObjectAccess soa(env); 1723 mirror::String* s = soa.Decode<mirror::String*>(java_string); 1724 gc::Heap* heap = Runtime::Current()->GetHeap(); 1725 if (heap->IsMovableObject(s)) { 1726 StackHandleScope<1> hs(soa.Self()); 1727 HandleWrapper<mirror::String> h(hs.NewHandleWrapper(&s)); 1728 if (!kUseReadBarrier) { 1729 heap->IncrementDisableMovingGC(soa.Self()); 1730 } else { 1731 // For the CC collector, we only need to wait for the thread flip rather than the whole GC 1732 // to occur thanks to the to-space invariant. 1733 heap->IncrementDisableThreadFlip(soa.Self()); 1734 } 1735 } 1736 if (is_copy != nullptr) { 1737 *is_copy = JNI_FALSE; 1738 } 1739 return static_cast<jchar*>(s->GetValue()); 1740 } 1741 1742 static void ReleaseStringCritical(JNIEnv* env, 1743 jstring java_string, 1744 const jchar* chars ATTRIBUTE_UNUSED) { 1745 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_string); 1746 ScopedObjectAccess soa(env); 1747 gc::Heap* heap = Runtime::Current()->GetHeap(); 1748 mirror::String* s = soa.Decode<mirror::String*>(java_string); 1749 if (heap->IsMovableObject(s)) { 1750 if (!kUseReadBarrier) { 1751 heap->DecrementDisableMovingGC(soa.Self()); 1752 } else { 1753 heap->DecrementDisableThreadFlip(soa.Self()); 1754 } 1755 } 1756 } 1757 1758 static const char* GetStringUTFChars(JNIEnv* env, jstring java_string, jboolean* is_copy) { 1759 if (java_string == nullptr) { 1760 return nullptr; 1761 } 1762 if (is_copy != nullptr) { 1763 *is_copy = JNI_TRUE; 1764 } 1765 ScopedObjectAccess soa(env); 1766 mirror::String* s = soa.Decode<mirror::String*>(java_string); 1767 size_t byte_count = s->GetUtfLength(); 1768 char* bytes = new char[byte_count + 1]; 1769 CHECK(bytes != nullptr); // bionic aborts anyway. 1770 const uint16_t* chars = s->GetValue(); 1771 ConvertUtf16ToModifiedUtf8(bytes, byte_count, chars, s->GetLength()); 1772 bytes[byte_count] = '\0'; 1773 return bytes; 1774 } 1775 1776 static void ReleaseStringUTFChars(JNIEnv*, jstring, const char* chars) { 1777 delete[] chars; 1778 } 1779 1780 static jsize GetArrayLength(JNIEnv* env, jarray java_array) { 1781 CHECK_NON_NULL_ARGUMENT_RETURN_ZERO(java_array); 1782 ScopedObjectAccess soa(env); 1783 mirror::Object* obj = soa.Decode<mirror::Object*>(java_array); 1784 if (UNLIKELY(!obj->IsArrayInstance())) { 1785 soa.Vm()->JniAbortF("GetArrayLength", "not an array: %s", PrettyTypeOf(obj).c_str()); 1786 return 0; 1787 } 1788 mirror::Array* array = obj->AsArray(); 1789 return array->GetLength(); 1790 } 1791 1792 static jobject GetObjectArrayElement(JNIEnv* env, jobjectArray java_array, jsize index) { 1793 CHECK_NON_NULL_ARGUMENT(java_array); 1794 ScopedObjectAccess soa(env); 1795 mirror::ObjectArray<mirror::Object>* array = 1796 soa.Decode<mirror::ObjectArray<mirror::Object>*>(java_array); 1797 return soa.AddLocalReference<jobject>(array->Get(index)); 1798 } 1799 1800 static void SetObjectArrayElement(JNIEnv* env, jobjectArray java_array, jsize index, 1801 jobject java_value) { 1802 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_array); 1803 ScopedObjectAccess soa(env); 1804 mirror::ObjectArray<mirror::Object>* array = 1805 soa.Decode<mirror::ObjectArray<mirror::Object>*>(java_array); 1806 mirror::Object* value = soa.Decode<mirror::Object*>(java_value); 1807 array->Set<false>(index, value); 1808 } 1809 1810 static jbooleanArray NewBooleanArray(JNIEnv* env, jsize length) { 1811 return NewPrimitiveArray<jbooleanArray, mirror::BooleanArray>(env, length); 1812 } 1813 1814 static jbyteArray NewByteArray(JNIEnv* env, jsize length) { 1815 return NewPrimitiveArray<jbyteArray, mirror::ByteArray>(env, length); 1816 } 1817 1818 static jcharArray NewCharArray(JNIEnv* env, jsize length) { 1819 return NewPrimitiveArray<jcharArray, mirror::CharArray>(env, length); 1820 } 1821 1822 static jdoubleArray NewDoubleArray(JNIEnv* env, jsize length) { 1823 return NewPrimitiveArray<jdoubleArray, mirror::DoubleArray>(env, length); 1824 } 1825 1826 static jfloatArray NewFloatArray(JNIEnv* env, jsize length) { 1827 return NewPrimitiveArray<jfloatArray, mirror::FloatArray>(env, length); 1828 } 1829 1830 static jintArray NewIntArray(JNIEnv* env, jsize length) { 1831 return NewPrimitiveArray<jintArray, mirror::IntArray>(env, length); 1832 } 1833 1834 static jlongArray NewLongArray(JNIEnv* env, jsize length) { 1835 return NewPrimitiveArray<jlongArray, mirror::LongArray>(env, length); 1836 } 1837 1838 static jobjectArray NewObjectArray(JNIEnv* env, jsize length, jclass element_jclass, 1839 jobject initial_element) { 1840 if (UNLIKELY(length < 0)) { 1841 JavaVmExtFromEnv(env)->JniAbortF("NewObjectArray", "negative array length: %d", length); 1842 return nullptr; 1843 } 1844 CHECK_NON_NULL_ARGUMENT(element_jclass); 1845 1846 // Compute the array class corresponding to the given element class. 1847 ScopedObjectAccess soa(env); 1848 mirror::Class* array_class; 1849 { 1850 mirror::Class* element_class = soa.Decode<mirror::Class*>(element_jclass); 1851 if (UNLIKELY(element_class->IsPrimitive())) { 1852 soa.Vm()->JniAbortF("NewObjectArray", "not an object type: %s", 1853 PrettyDescriptor(element_class).c_str()); 1854 return nullptr; 1855 } 1856 ClassLinker* class_linker = Runtime::Current()->GetClassLinker(); 1857 array_class = class_linker->FindArrayClass(soa.Self(), &element_class); 1858 if (UNLIKELY(array_class == nullptr)) { 1859 return nullptr; 1860 } 1861 } 1862 1863 // Allocate and initialize if necessary. 1864 mirror::ObjectArray<mirror::Object>* result = 1865 mirror::ObjectArray<mirror::Object>::Alloc(soa.Self(), array_class, length); 1866 if (result != nullptr && initial_element != nullptr) { 1867 mirror::Object* initial_object = soa.Decode<mirror::Object*>(initial_element); 1868 if (initial_object != nullptr) { 1869 mirror::Class* element_class = result->GetClass()->GetComponentType(); 1870 if (UNLIKELY(!element_class->IsAssignableFrom(initial_object->GetClass()))) { 1871 soa.Vm()->JniAbortF("NewObjectArray", "cannot assign object of type '%s' to array with " 1872 "element type of '%s'", 1873 PrettyDescriptor(initial_object->GetClass()).c_str(), 1874 PrettyDescriptor(element_class).c_str()); 1875 return nullptr; 1876 } else { 1877 for (jsize i = 0; i < length; ++i) { 1878 result->SetWithoutChecks<false>(i, initial_object); 1879 } 1880 } 1881 } 1882 } 1883 return soa.AddLocalReference<jobjectArray>(result); 1884 } 1885 1886 static jshortArray NewShortArray(JNIEnv* env, jsize length) { 1887 return NewPrimitiveArray<jshortArray, mirror::ShortArray>(env, length); 1888 } 1889 1890 static void* GetPrimitiveArrayCritical(JNIEnv* env, jarray java_array, jboolean* is_copy) { 1891 CHECK_NON_NULL_ARGUMENT(java_array); 1892 ScopedObjectAccess soa(env); 1893 mirror::Array* array = soa.Decode<mirror::Array*>(java_array); 1894 if (UNLIKELY(!array->GetClass()->IsPrimitiveArray())) { 1895 soa.Vm()->JniAbortF("GetPrimitiveArrayCritical", "expected primitive array, given %s", 1896 PrettyDescriptor(array->GetClass()).c_str()); 1897 return nullptr; 1898 } 1899 gc::Heap* heap = Runtime::Current()->GetHeap(); 1900 if (heap->IsMovableObject(array)) { 1901 if (!kUseReadBarrier) { 1902 heap->IncrementDisableMovingGC(soa.Self()); 1903 } else { 1904 // For the CC collector, we only need to wait for the thread flip rather than the whole GC 1905 // to occur thanks to the to-space invariant. 1906 heap->IncrementDisableThreadFlip(soa.Self()); 1907 } 1908 // Re-decode in case the object moved since IncrementDisableGC waits for GC to complete. 1909 array = soa.Decode<mirror::Array*>(java_array); 1910 } 1911 if (is_copy != nullptr) { 1912 *is_copy = JNI_FALSE; 1913 } 1914 return array->GetRawData(array->GetClass()->GetComponentSize(), 0); 1915 } 1916 1917 static void ReleasePrimitiveArrayCritical(JNIEnv* env, jarray java_array, void* elements, 1918 jint mode) { 1919 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_array); 1920 ScopedObjectAccess soa(env); 1921 mirror::Array* array = soa.Decode<mirror::Array*>(java_array); 1922 if (UNLIKELY(!array->GetClass()->IsPrimitiveArray())) { 1923 soa.Vm()->JniAbortF("ReleasePrimitiveArrayCritical", "expected primitive array, given %s", 1924 PrettyDescriptor(array->GetClass()).c_str()); 1925 return; 1926 } 1927 const size_t component_size = array->GetClass()->GetComponentSize(); 1928 ReleasePrimitiveArray(soa, array, component_size, elements, mode); 1929 } 1930 1931 static jboolean* GetBooleanArrayElements(JNIEnv* env, jbooleanArray array, jboolean* is_copy) { 1932 return GetPrimitiveArray<jbooleanArray, jboolean, mirror::BooleanArray>(env, array, is_copy); 1933 } 1934 1935 static jbyte* GetByteArrayElements(JNIEnv* env, jbyteArray array, jboolean* is_copy) { 1936 return GetPrimitiveArray<jbyteArray, jbyte, mirror::ByteArray>(env, array, is_copy); 1937 } 1938 1939 static jchar* GetCharArrayElements(JNIEnv* env, jcharArray array, jboolean* is_copy) { 1940 return GetPrimitiveArray<jcharArray, jchar, mirror::CharArray>(env, array, is_copy); 1941 } 1942 1943 static jdouble* GetDoubleArrayElements(JNIEnv* env, jdoubleArray array, jboolean* is_copy) { 1944 return GetPrimitiveArray<jdoubleArray, jdouble, mirror::DoubleArray>(env, array, is_copy); 1945 } 1946 1947 static jfloat* GetFloatArrayElements(JNIEnv* env, jfloatArray array, jboolean* is_copy) { 1948 return GetPrimitiveArray<jfloatArray, jfloat, mirror::FloatArray>(env, array, is_copy); 1949 } 1950 1951 static jint* GetIntArrayElements(JNIEnv* env, jintArray array, jboolean* is_copy) { 1952 return GetPrimitiveArray<jintArray, jint, mirror::IntArray>(env, array, is_copy); 1953 } 1954 1955 static jlong* GetLongArrayElements(JNIEnv* env, jlongArray array, jboolean* is_copy) { 1956 return GetPrimitiveArray<jlongArray, jlong, mirror::LongArray>(env, array, is_copy); 1957 } 1958 1959 static jshort* GetShortArrayElements(JNIEnv* env, jshortArray array, jboolean* is_copy) { 1960 return GetPrimitiveArray<jshortArray, jshort, mirror::ShortArray>(env, array, is_copy); 1961 } 1962 1963 static void ReleaseBooleanArrayElements(JNIEnv* env, jbooleanArray array, jboolean* elements, 1964 jint mode) { 1965 ReleasePrimitiveArray<jbooleanArray, jboolean, mirror::BooleanArray>(env, array, elements, 1966 mode); 1967 } 1968 1969 static void ReleaseByteArrayElements(JNIEnv* env, jbyteArray array, jbyte* elements, jint mode) { 1970 ReleasePrimitiveArray<jbyteArray, jbyte, mirror::ByteArray>(env, array, elements, mode); 1971 } 1972 1973 static void ReleaseCharArrayElements(JNIEnv* env, jcharArray array, jchar* elements, jint mode) { 1974 ReleasePrimitiveArray<jcharArray, jchar, mirror::CharArray>(env, array, elements, mode); 1975 } 1976 1977 static void ReleaseDoubleArrayElements(JNIEnv* env, jdoubleArray array, jdouble* elements, 1978 jint mode) { 1979 ReleasePrimitiveArray<jdoubleArray, jdouble, mirror::DoubleArray>(env, array, elements, mode); 1980 } 1981 1982 static void ReleaseFloatArrayElements(JNIEnv* env, jfloatArray array, jfloat* elements, 1983 jint mode) { 1984 ReleasePrimitiveArray<jfloatArray, jfloat, mirror::FloatArray>(env, array, elements, mode); 1985 } 1986 1987 static void ReleaseIntArrayElements(JNIEnv* env, jintArray array, jint* elements, jint mode) { 1988 ReleasePrimitiveArray<jintArray, jint, mirror::IntArray>(env, array, elements, mode); 1989 } 1990 1991 static void ReleaseLongArrayElements(JNIEnv* env, jlongArray array, jlong* elements, jint mode) { 1992 ReleasePrimitiveArray<jlongArray, jlong, mirror::LongArray>(env, array, elements, mode); 1993 } 1994 1995 static void ReleaseShortArrayElements(JNIEnv* env, jshortArray array, jshort* elements, 1996 jint mode) { 1997 ReleasePrimitiveArray<jshortArray, jshort, mirror::ShortArray>(env, array, elements, mode); 1998 } 1999 2000 static void GetBooleanArrayRegion(JNIEnv* env, jbooleanArray array, jsize start, jsize length, 2001 jboolean* buf) { 2002 GetPrimitiveArrayRegion<jbooleanArray, jboolean, mirror::BooleanArray>(env, array, start, 2003 length, buf); 2004 } 2005 2006 static void GetByteArrayRegion(JNIEnv* env, jbyteArray array, jsize start, jsize length, 2007 jbyte* buf) { 2008 GetPrimitiveArrayRegion<jbyteArray, jbyte, mirror::ByteArray>(env, array, start, length, buf); 2009 } 2010 2011 static void GetCharArrayRegion(JNIEnv* env, jcharArray array, jsize start, jsize length, 2012 jchar* buf) { 2013 GetPrimitiveArrayRegion<jcharArray, jchar, mirror::CharArray>(env, array, start, length, buf); 2014 } 2015 2016 static void GetDoubleArrayRegion(JNIEnv* env, jdoubleArray array, jsize start, jsize length, 2017 jdouble* buf) { 2018 GetPrimitiveArrayRegion<jdoubleArray, jdouble, mirror::DoubleArray>(env, array, start, length, 2019 buf); 2020 } 2021 2022 static void GetFloatArrayRegion(JNIEnv* env, jfloatArray array, jsize start, jsize length, 2023 jfloat* buf) { 2024 GetPrimitiveArrayRegion<jfloatArray, jfloat, mirror::FloatArray>(env, array, start, length, 2025 buf); 2026 } 2027 2028 static void GetIntArrayRegion(JNIEnv* env, jintArray array, jsize start, jsize length, 2029 jint* buf) { 2030 GetPrimitiveArrayRegion<jintArray, jint, mirror::IntArray>(env, array, start, length, buf); 2031 } 2032 2033 static void GetLongArrayRegion(JNIEnv* env, jlongArray array, jsize start, jsize length, 2034 jlong* buf) { 2035 GetPrimitiveArrayRegion<jlongArray, jlong, mirror::LongArray>(env, array, start, length, buf); 2036 } 2037 2038 static void GetShortArrayRegion(JNIEnv* env, jshortArray array, jsize start, jsize length, 2039 jshort* buf) { 2040 GetPrimitiveArrayRegion<jshortArray, jshort, mirror::ShortArray>(env, array, start, length, 2041 buf); 2042 } 2043 2044 static void SetBooleanArrayRegion(JNIEnv* env, jbooleanArray array, jsize start, jsize length, 2045 const jboolean* buf) { 2046 SetPrimitiveArrayRegion<jbooleanArray, jboolean, mirror::BooleanArray>(env, array, start, 2047 length, buf); 2048 } 2049 2050 static void SetByteArrayRegion(JNIEnv* env, jbyteArray array, jsize start, jsize length, 2051 const jbyte* buf) { 2052 SetPrimitiveArrayRegion<jbyteArray, jbyte, mirror::ByteArray>(env, array, start, length, buf); 2053 } 2054 2055 static void SetCharArrayRegion(JNIEnv* env, jcharArray array, jsize start, jsize length, 2056 const jchar* buf) { 2057 SetPrimitiveArrayRegion<jcharArray, jchar, mirror::CharArray>(env, array, start, length, buf); 2058 } 2059 2060 static void SetDoubleArrayRegion(JNIEnv* env, jdoubleArray array, jsize start, jsize length, 2061 const jdouble* buf) { 2062 SetPrimitiveArrayRegion<jdoubleArray, jdouble, mirror::DoubleArray>(env, array, start, length, 2063 buf); 2064 } 2065 2066 static void SetFloatArrayRegion(JNIEnv* env, jfloatArray array, jsize start, jsize length, 2067 const jfloat* buf) { 2068 SetPrimitiveArrayRegion<jfloatArray, jfloat, mirror::FloatArray>(env, array, start, length, 2069 buf); 2070 } 2071 2072 static void SetIntArrayRegion(JNIEnv* env, jintArray array, jsize start, jsize length, 2073 const jint* buf) { 2074 SetPrimitiveArrayRegion<jintArray, jint, mirror::IntArray>(env, array, start, length, buf); 2075 } 2076 2077 static void SetLongArrayRegion(JNIEnv* env, jlongArray array, jsize start, jsize length, 2078 const jlong* buf) { 2079 SetPrimitiveArrayRegion<jlongArray, jlong, mirror::LongArray>(env, array, start, length, buf); 2080 } 2081 2082 static void SetShortArrayRegion(JNIEnv* env, jshortArray array, jsize start, jsize length, 2083 const jshort* buf) { 2084 SetPrimitiveArrayRegion<jshortArray, jshort, mirror::ShortArray>(env, array, start, length, 2085 buf); 2086 } 2087 2088 static jint RegisterNatives(JNIEnv* env, jclass java_class, const JNINativeMethod* methods, 2089 jint method_count) { 2090 return RegisterNativeMethods(env, java_class, methods, method_count, true); 2091 } 2092 2093 static jint RegisterNativeMethods(JNIEnv* env, jclass java_class, const JNINativeMethod* methods, 2094 jint method_count, bool return_errors) { 2095 if (UNLIKELY(method_count < 0)) { 2096 JavaVmExtFromEnv(env)->JniAbortF("RegisterNatives", "negative method count: %d", 2097 method_count); 2098 return JNI_ERR; // Not reached except in unit tests. 2099 } 2100 CHECK_NON_NULL_ARGUMENT_FN_NAME("RegisterNatives", java_class, JNI_ERR); 2101 ScopedObjectAccess soa(env); 2102 mirror::Class* c = soa.Decode<mirror::Class*>(java_class); 2103 if (UNLIKELY(method_count == 0)) { 2104 LOG(WARNING) << "JNI RegisterNativeMethods: attempt to register 0 native methods for " 2105 << PrettyDescriptor(c); 2106 return JNI_OK; 2107 } 2108 CHECK_NON_NULL_ARGUMENT_FN_NAME("RegisterNatives", methods, JNI_ERR); 2109 for (jint i = 0; i < method_count; ++i) { 2110 const char* name = methods[i].name; 2111 const char* sig = methods[i].signature; 2112 const void* fnPtr = methods[i].fnPtr; 2113 if (UNLIKELY(name == nullptr)) { 2114 ReportInvalidJNINativeMethod(soa, c, "method name", i, return_errors); 2115 return JNI_ERR; 2116 } else if (UNLIKELY(sig == nullptr)) { 2117 ReportInvalidJNINativeMethod(soa, c, "method signature", i, return_errors); 2118 return JNI_ERR; 2119 } else if (UNLIKELY(fnPtr == nullptr)) { 2120 ReportInvalidJNINativeMethod(soa, c, "native function", i, return_errors); 2121 return JNI_ERR; 2122 } 2123 bool is_fast = false; 2124 // Notes about fast JNI calls: 2125 // 2126 // On a normal JNI call, the calling thread usually transitions 2127 // from the kRunnable state to the kNative state. But if the 2128 // called native function needs to access any Java object, it 2129 // will have to transition back to the kRunnable state. 2130 // 2131 // There is a cost to this double transition. For a JNI call 2132 // that should be quick, this cost may dominate the call cost. 2133 // 2134 // On a fast JNI call, the calling thread avoids this double 2135 // transition by not transitioning from kRunnable to kNative and 2136 // stays in the kRunnable state. 2137 // 2138 // There are risks to using a fast JNI call because it can delay 2139 // a response to a thread suspension request which is typically 2140 // used for a GC root scanning, etc. If a fast JNI call takes a 2141 // long time, it could cause longer thread suspension latency 2142 // and GC pauses. 2143 // 2144 // Thus, fast JNI should be used with care. It should be used 2145 // for a JNI call that takes a short amount of time (eg. no 2146 // long-running loop) and does not block (eg. no locks, I/O, 2147 // etc.) 2148 // 2149 // A '!' prefix in the signature in the JNINativeMethod 2150 // indicates that it's a fast JNI call and the runtime omits the 2151 // thread state transition from kRunnable to kNative at the 2152 // entry. 2153 if (*sig == '!') { 2154 is_fast = true; 2155 ++sig; 2156 } 2157 2158 // Note: the right order is to try to find the method locally 2159 // first, either as a direct or a virtual method. Then move to 2160 // the parent. 2161 ArtMethod* m = nullptr; 2162 bool warn_on_going_to_parent = down_cast<JNIEnvExt*>(env)->vm->IsCheckJniEnabled(); 2163 for (mirror::Class* current_class = c; 2164 current_class != nullptr; 2165 current_class = current_class->GetSuperClass()) { 2166 // Search first only comparing methods which are native. 2167 m = FindMethod<true>(current_class, name, sig); 2168 if (m != nullptr) { 2169 break; 2170 } 2171 2172 // Search again comparing to all methods, to find non-native methods that match. 2173 m = FindMethod<false>(current_class, name, sig); 2174 if (m != nullptr) { 2175 break; 2176 } 2177 2178 if (warn_on_going_to_parent) { 2179 LOG(WARNING) << "CheckJNI: method to register \"" << name << "\" not in the given class. " 2180 << "This is slow, consider changing your RegisterNatives calls."; 2181 warn_on_going_to_parent = false; 2182 } 2183 } 2184 2185 if (m == nullptr) { 2186 LOG(return_errors ? ERROR : INTERNAL_FATAL) << "Failed to register native method " 2187 << PrettyDescriptor(c) << "." << name << sig << " in " 2188 << c->GetDexCache()->GetLocation()->ToModifiedUtf8(); 2189 // Safe to pass in LOG(FATAL) since the log object aborts in destructor and only goes 2190 // out of scope after the DumpClass is done executing. 2191 c->DumpClass(LOG(return_errors ? ERROR : FATAL), mirror::Class::kDumpClassFullDetail); 2192 ThrowNoSuchMethodError(soa, c, name, sig, "static or non-static"); 2193 return JNI_ERR; 2194 } else if (!m->IsNative()) { 2195 LOG(return_errors ? ERROR : FATAL) << "Failed to register non-native method " 2196 << PrettyDescriptor(c) << "." << name << sig 2197 << " as native"; 2198 ThrowNoSuchMethodError(soa, c, name, sig, "native"); 2199 return JNI_ERR; 2200 } 2201 2202 VLOG(jni) << "[Registering JNI native method " << PrettyMethod(m) << "]"; 2203 2204 m->RegisterNative(fnPtr, is_fast); 2205 } 2206 return JNI_OK; 2207 } 2208 2209 static jint UnregisterNatives(JNIEnv* env, jclass java_class) { 2210 CHECK_NON_NULL_ARGUMENT_RETURN(java_class, JNI_ERR); 2211 ScopedObjectAccess soa(env); 2212 mirror::Class* c = soa.Decode<mirror::Class*>(java_class); 2213 2214 VLOG(jni) << "[Unregistering JNI native methods for " << PrettyClass(c) << "]"; 2215 2216 size_t unregistered_count = 0; 2217 auto pointer_size = Runtime::Current()->GetClassLinker()->GetImagePointerSize(); 2218 for (auto& m : c->GetMethods(pointer_size)) { 2219 if (m.IsNative()) { 2220 m.UnregisterNative(); 2221 unregistered_count++; 2222 } 2223 } 2224 2225 if (unregistered_count == 0) { 2226 LOG(WARNING) << "JNI UnregisterNatives: attempt to unregister native methods of class '" 2227 << PrettyDescriptor(c) << "' that contains no native methods"; 2228 } 2229 return JNI_OK; 2230 } 2231 2232 static jint MonitorEnter(JNIEnv* env, jobject java_object) NO_THREAD_SAFETY_ANALYSIS { 2233 CHECK_NON_NULL_ARGUMENT_RETURN(java_object, JNI_ERR); 2234 ScopedObjectAccess soa(env); 2235 mirror::Object* o = soa.Decode<mirror::Object*>(java_object); 2236 o = o->MonitorEnter(soa.Self()); 2237 if (soa.Self()->IsExceptionPending()) { 2238 return JNI_ERR; 2239 } 2240 soa.Env()->monitors.Add(o); 2241 return JNI_OK; 2242 } 2243 2244 static jint MonitorExit(JNIEnv* env, jobject java_object) NO_THREAD_SAFETY_ANALYSIS { 2245 CHECK_NON_NULL_ARGUMENT_RETURN(java_object, JNI_ERR); 2246 ScopedObjectAccess soa(env); 2247 mirror::Object* o = soa.Decode<mirror::Object*>(java_object); 2248 o->MonitorExit(soa.Self()); 2249 if (soa.Self()->IsExceptionPending()) { 2250 return JNI_ERR; 2251 } 2252 soa.Env()->monitors.Remove(o); 2253 return JNI_OK; 2254 } 2255 2256 static jint GetJavaVM(JNIEnv* env, JavaVM** vm) { 2257 CHECK_NON_NULL_ARGUMENT_RETURN(vm, JNI_ERR); 2258 Runtime* runtime = Runtime::Current(); 2259 if (runtime != nullptr) { 2260 *vm = runtime->GetJavaVM(); 2261 } else { 2262 *vm = nullptr; 2263 } 2264 return (*vm != nullptr) ? JNI_OK : JNI_ERR; 2265 } 2266 2267 static jobject NewDirectByteBuffer(JNIEnv* env, void* address, jlong capacity) { 2268 if (capacity < 0) { 2269 JavaVmExtFromEnv(env)->JniAbortF("NewDirectByteBuffer", "negative buffer capacity: %" PRId64, 2270 capacity); 2271 return nullptr; 2272 } 2273 if (address == nullptr && capacity != 0) { 2274 JavaVmExtFromEnv(env)->JniAbortF("NewDirectByteBuffer", 2275 "non-zero capacity for nullptr pointer: %" PRId64, capacity); 2276 return nullptr; 2277 } 2278 2279 // At the moment, the capacity of DirectByteBuffer is limited to a signed int. 2280 if (capacity > INT_MAX) { 2281 JavaVmExtFromEnv(env)->JniAbortF("NewDirectByteBuffer", 2282 "buffer capacity greater than maximum jint: %" PRId64, 2283 capacity); 2284 return nullptr; 2285 } 2286 jlong address_arg = reinterpret_cast<jlong>(address); 2287 jint capacity_arg = static_cast<jint>(capacity); 2288 2289 jobject result = env->NewObject(WellKnownClasses::java_nio_DirectByteBuffer, 2290 WellKnownClasses::java_nio_DirectByteBuffer_init, 2291 address_arg, capacity_arg); 2292 return static_cast<JNIEnvExt*>(env)->self->IsExceptionPending() ? nullptr : result; 2293 } 2294 2295 static void* GetDirectBufferAddress(JNIEnv* env, jobject java_buffer) { 2296 return reinterpret_cast<void*>(env->GetLongField( 2297 java_buffer, WellKnownClasses::java_nio_DirectByteBuffer_effectiveDirectAddress)); 2298 } 2299 2300 static jlong GetDirectBufferCapacity(JNIEnv* env, jobject java_buffer) { 2301 return static_cast<jlong>(env->GetIntField( 2302 java_buffer, WellKnownClasses::java_nio_DirectByteBuffer_capacity)); 2303 } 2304 2305 static jobjectRefType GetObjectRefType(JNIEnv* env ATTRIBUTE_UNUSED, jobject java_object) { 2306 if (java_object == nullptr) { 2307 return JNIInvalidRefType; 2308 } 2309 2310 // Do we definitely know what kind of reference this is? 2311 IndirectRef ref = reinterpret_cast<IndirectRef>(java_object); 2312 IndirectRefKind kind = GetIndirectRefKind(ref); 2313 switch (kind) { 2314 case kLocal: 2315 return JNILocalRefType; 2316 case kGlobal: 2317 return JNIGlobalRefType; 2318 case kWeakGlobal: 2319 return JNIWeakGlobalRefType; 2320 case kHandleScopeOrInvalid: 2321 // Assume value is in a handle scope. 2322 return JNILocalRefType; 2323 } 2324 LOG(FATAL) << "IndirectRefKind[" << kind << "]"; 2325 UNREACHABLE(); 2326 } 2327 2328 private: 2329 static jint EnsureLocalCapacityInternal(ScopedObjectAccess& soa, jint desired_capacity, 2330 const char* caller) 2331 SHARED_REQUIRES(Locks::mutator_lock_) { 2332 // TODO: we should try to expand the table if necessary. 2333 if (desired_capacity < 0 || desired_capacity > static_cast<jint>(kLocalsMax)) { 2334 LOG(ERROR) << "Invalid capacity given to " << caller << ": " << desired_capacity; 2335 return JNI_ERR; 2336 } 2337 // TODO: this isn't quite right, since "capacity" includes holes. 2338 const size_t capacity = soa.Env()->locals.Capacity(); 2339 bool okay = (static_cast<jint>(kLocalsMax - capacity) >= desired_capacity); 2340 if (!okay) { 2341 soa.Self()->ThrowOutOfMemoryError(caller); 2342 } 2343 return okay ? JNI_OK : JNI_ERR; 2344 } 2345 2346 template<typename JniT, typename ArtT> 2347 static JniT NewPrimitiveArray(JNIEnv* env, jsize length) { 2348 ScopedObjectAccess soa(env); 2349 if (UNLIKELY(length < 0)) { 2350 soa.Vm()->JniAbortF("NewPrimitiveArray", "negative array length: %d", length); 2351 return nullptr; 2352 } 2353 ArtT* result = ArtT::Alloc(soa.Self(), length); 2354 return soa.AddLocalReference<JniT>(result); 2355 } 2356 2357 template <typename JArrayT, typename ElementT, typename ArtArrayT> 2358 static ArtArrayT* DecodeAndCheckArrayType(ScopedObjectAccess& soa, JArrayT java_array, 2359 const char* fn_name, const char* operation) 2360 SHARED_REQUIRES(Locks::mutator_lock_) { 2361 ArtArrayT* array = soa.Decode<ArtArrayT*>(java_array); 2362 if (UNLIKELY(ArtArrayT::GetArrayClass() != array->GetClass())) { 2363 soa.Vm()->JniAbortF(fn_name, 2364 "attempt to %s %s primitive array elements with an object of type %s", 2365 operation, 2366 PrettyDescriptor(ArtArrayT::GetArrayClass()->GetComponentType()).c_str(), 2367 PrettyDescriptor(array->GetClass()).c_str()); 2368 return nullptr; 2369 } 2370 DCHECK_EQ(sizeof(ElementT), array->GetClass()->GetComponentSize()); 2371 return array; 2372 } 2373 2374 template <typename ArrayT, typename ElementT, typename ArtArrayT> 2375 static ElementT* GetPrimitiveArray(JNIEnv* env, ArrayT java_array, jboolean* is_copy) { 2376 CHECK_NON_NULL_ARGUMENT(java_array); 2377 ScopedObjectAccess soa(env); 2378 ArtArrayT* array = DecodeAndCheckArrayType<ArrayT, ElementT, ArtArrayT>(soa, java_array, 2379 "GetArrayElements", 2380 "get"); 2381 if (UNLIKELY(array == nullptr)) { 2382 return nullptr; 2383 } 2384 // Only make a copy if necessary. 2385 if (Runtime::Current()->GetHeap()->IsMovableObject(array)) { 2386 if (is_copy != nullptr) { 2387 *is_copy = JNI_TRUE; 2388 } 2389 const size_t component_size = sizeof(ElementT); 2390 size_t size = array->GetLength() * component_size; 2391 void* data = new uint64_t[RoundUp(size, 8) / 8]; 2392 memcpy(data, array->GetData(), size); 2393 return reinterpret_cast<ElementT*>(data); 2394 } else { 2395 if (is_copy != nullptr) { 2396 *is_copy = JNI_FALSE; 2397 } 2398 return reinterpret_cast<ElementT*>(array->GetData()); 2399 } 2400 } 2401 2402 template <typename ArrayT, typename ElementT, typename ArtArrayT> 2403 static void ReleasePrimitiveArray(JNIEnv* env, ArrayT java_array, ElementT* elements, jint mode) { 2404 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_array); 2405 ScopedObjectAccess soa(env); 2406 ArtArrayT* array = DecodeAndCheckArrayType<ArrayT, ElementT, ArtArrayT>(soa, java_array, 2407 "ReleaseArrayElements", 2408 "release"); 2409 if (array == nullptr) { 2410 return; 2411 } 2412 ReleasePrimitiveArray(soa, array, sizeof(ElementT), elements, mode); 2413 } 2414 2415 static void ReleasePrimitiveArray(ScopedObjectAccess& soa, mirror::Array* array, 2416 size_t component_size, void* elements, jint mode) 2417 SHARED_REQUIRES(Locks::mutator_lock_) { 2418 void* array_data = array->GetRawData(component_size, 0); 2419 gc::Heap* heap = Runtime::Current()->GetHeap(); 2420 bool is_copy = array_data != elements; 2421 size_t bytes = array->GetLength() * component_size; 2422 if (is_copy) { 2423 // Sanity check: If elements is not the same as the java array's data, it better not be a 2424 // heap address. TODO: This might be slow to check, may be worth keeping track of which 2425 // copies we make? 2426 if (heap->IsNonDiscontinuousSpaceHeapAddress(reinterpret_cast<mirror::Object*>(elements))) { 2427 soa.Vm()->JniAbortF("ReleaseArrayElements", 2428 "invalid element pointer %p, array elements are %p", 2429 reinterpret_cast<void*>(elements), array_data); 2430 return; 2431 } 2432 if (mode != JNI_ABORT) { 2433 memcpy(array_data, elements, bytes); 2434 } else if (kWarnJniAbort && memcmp(array_data, elements, bytes) != 0) { 2435 // Warn if we have JNI_ABORT and the arrays don't match since this is usually an error. 2436 LOG(WARNING) << "Possible incorrect JNI_ABORT in Release*ArrayElements"; 2437 soa.Self()->DumpJavaStack(LOG(WARNING)); 2438 } 2439 } 2440 if (mode != JNI_COMMIT) { 2441 if (is_copy) { 2442 delete[] reinterpret_cast<uint64_t*>(elements); 2443 } else if (heap->IsMovableObject(array)) { 2444 // Non copy to a movable object must means that we had disabled the moving GC. 2445 if (!kUseReadBarrier) { 2446 heap->DecrementDisableMovingGC(soa.Self()); 2447 } else { 2448 heap->DecrementDisableThreadFlip(soa.Self()); 2449 } 2450 } 2451 } 2452 } 2453 2454 template <typename JArrayT, typename ElementT, typename ArtArrayT> 2455 static void GetPrimitiveArrayRegion(JNIEnv* env, JArrayT java_array, 2456 jsize start, jsize length, ElementT* buf) { 2457 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_array); 2458 ScopedObjectAccess soa(env); 2459 ArtArrayT* array = 2460 DecodeAndCheckArrayType<JArrayT, ElementT, ArtArrayT>(soa, java_array, 2461 "GetPrimitiveArrayRegion", 2462 "get region of"); 2463 if (array != nullptr) { 2464 if (start < 0 || length < 0 || length > array->GetLength() - start) { 2465 ThrowAIOOBE(soa, array, start, length, "src"); 2466 } else { 2467 CHECK_NON_NULL_MEMCPY_ARGUMENT(length, buf); 2468 ElementT* data = array->GetData(); 2469 memcpy(buf, data + start, length * sizeof(ElementT)); 2470 } 2471 } 2472 } 2473 2474 template <typename JArrayT, typename ElementT, typename ArtArrayT> 2475 static void SetPrimitiveArrayRegion(JNIEnv* env, JArrayT java_array, 2476 jsize start, jsize length, const ElementT* buf) { 2477 CHECK_NON_NULL_ARGUMENT_RETURN_VOID(java_array); 2478 ScopedObjectAccess soa(env); 2479 ArtArrayT* array = 2480 DecodeAndCheckArrayType<JArrayT, ElementT, ArtArrayT>(soa, java_array, 2481 "SetPrimitiveArrayRegion", 2482 "set region of"); 2483 if (array != nullptr) { 2484 if (start < 0 || length < 0 || length > array->GetLength() - start) { 2485 ThrowAIOOBE(soa, array, start, length, "dst"); 2486 } else { 2487 CHECK_NON_NULL_MEMCPY_ARGUMENT(length, buf); 2488 ElementT* data = array->GetData(); 2489 memcpy(data + start, buf, length * sizeof(ElementT)); 2490 } 2491 } 2492 } 2493}; 2494 2495const JNINativeInterface gJniNativeInterface = { 2496 nullptr, // reserved0. 2497 nullptr, // reserved1. 2498 nullptr, // reserved2. 2499 nullptr, // reserved3. 2500 JNI::GetVersion, 2501 JNI::DefineClass, 2502 JNI::FindClass, 2503 JNI::FromReflectedMethod, 2504 JNI::FromReflectedField, 2505 JNI::ToReflectedMethod, 2506 JNI::GetSuperclass, 2507 JNI::IsAssignableFrom, 2508 JNI::ToReflectedField, 2509 JNI::Throw, 2510 JNI::ThrowNew, 2511 JNI::ExceptionOccurred, 2512 JNI::ExceptionDescribe, 2513 JNI::ExceptionClear, 2514 JNI::FatalError, 2515 JNI::PushLocalFrame, 2516 JNI::PopLocalFrame, 2517 JNI::NewGlobalRef, 2518 JNI::DeleteGlobalRef, 2519 JNI::DeleteLocalRef, 2520 JNI::IsSameObject, 2521 JNI::NewLocalRef, 2522 JNI::EnsureLocalCapacity, 2523 JNI::AllocObject, 2524 JNI::NewObject, 2525 JNI::NewObjectV, 2526 JNI::NewObjectA, 2527 JNI::GetObjectClass, 2528 JNI::IsInstanceOf, 2529 JNI::GetMethodID, 2530 JNI::CallObjectMethod, 2531 JNI::CallObjectMethodV, 2532 JNI::CallObjectMethodA, 2533 JNI::CallBooleanMethod, 2534 JNI::CallBooleanMethodV, 2535 JNI::CallBooleanMethodA, 2536 JNI::CallByteMethod, 2537 JNI::CallByteMethodV, 2538 JNI::CallByteMethodA, 2539 JNI::CallCharMethod, 2540 JNI::CallCharMethodV, 2541 JNI::CallCharMethodA, 2542 JNI::CallShortMethod, 2543 JNI::CallShortMethodV, 2544 JNI::CallShortMethodA, 2545 JNI::CallIntMethod, 2546 JNI::CallIntMethodV, 2547 JNI::CallIntMethodA, 2548 JNI::CallLongMethod, 2549 JNI::CallLongMethodV, 2550 JNI::CallLongMethodA, 2551 JNI::CallFloatMethod, 2552 JNI::CallFloatMethodV, 2553 JNI::CallFloatMethodA, 2554 JNI::CallDoubleMethod, 2555 JNI::CallDoubleMethodV, 2556 JNI::CallDoubleMethodA, 2557 JNI::CallVoidMethod, 2558 JNI::CallVoidMethodV, 2559 JNI::CallVoidMethodA, 2560 JNI::CallNonvirtualObjectMethod, 2561 JNI::CallNonvirtualObjectMethodV, 2562 JNI::CallNonvirtualObjectMethodA, 2563 JNI::CallNonvirtualBooleanMethod, 2564 JNI::CallNonvirtualBooleanMethodV, 2565 JNI::CallNonvirtualBooleanMethodA, 2566 JNI::CallNonvirtualByteMethod, 2567 JNI::CallNonvirtualByteMethodV, 2568 JNI::CallNonvirtualByteMethodA, 2569 JNI::CallNonvirtualCharMethod, 2570 JNI::CallNonvirtualCharMethodV, 2571 JNI::CallNonvirtualCharMethodA, 2572 JNI::CallNonvirtualShortMethod, 2573 JNI::CallNonvirtualShortMethodV, 2574 JNI::CallNonvirtualShortMethodA, 2575 JNI::CallNonvirtualIntMethod, 2576 JNI::CallNonvirtualIntMethodV, 2577 JNI::CallNonvirtualIntMethodA, 2578 JNI::CallNonvirtualLongMethod, 2579 JNI::CallNonvirtualLongMethodV, 2580 JNI::CallNonvirtualLongMethodA, 2581 JNI::CallNonvirtualFloatMethod, 2582 JNI::CallNonvirtualFloatMethodV, 2583 JNI::CallNonvirtualFloatMethodA, 2584 JNI::CallNonvirtualDoubleMethod, 2585 JNI::CallNonvirtualDoubleMethodV, 2586 JNI::CallNonvirtualDoubleMethodA, 2587 JNI::CallNonvirtualVoidMethod, 2588 JNI::CallNonvirtualVoidMethodV, 2589 JNI::CallNonvirtualVoidMethodA, 2590 JNI::GetFieldID, 2591 JNI::GetObjectField, 2592 JNI::GetBooleanField, 2593 JNI::GetByteField, 2594 JNI::GetCharField, 2595 JNI::GetShortField, 2596 JNI::GetIntField, 2597 JNI::GetLongField, 2598 JNI::GetFloatField, 2599 JNI::GetDoubleField, 2600 JNI::SetObjectField, 2601 JNI::SetBooleanField, 2602 JNI::SetByteField, 2603 JNI::SetCharField, 2604 JNI::SetShortField, 2605 JNI::SetIntField, 2606 JNI::SetLongField, 2607 JNI::SetFloatField, 2608 JNI::SetDoubleField, 2609 JNI::GetStaticMethodID, 2610 JNI::CallStaticObjectMethod, 2611 JNI::CallStaticObjectMethodV, 2612 JNI::CallStaticObjectMethodA, 2613 JNI::CallStaticBooleanMethod, 2614 JNI::CallStaticBooleanMethodV, 2615 JNI::CallStaticBooleanMethodA, 2616 JNI::CallStaticByteMethod, 2617 JNI::CallStaticByteMethodV, 2618 JNI::CallStaticByteMethodA, 2619 JNI::CallStaticCharMethod, 2620 JNI::CallStaticCharMethodV, 2621 JNI::CallStaticCharMethodA, 2622 JNI::CallStaticShortMethod, 2623 JNI::CallStaticShortMethodV, 2624 JNI::CallStaticShortMethodA, 2625 JNI::CallStaticIntMethod, 2626 JNI::CallStaticIntMethodV, 2627 JNI::CallStaticIntMethodA, 2628 JNI::CallStaticLongMethod, 2629 JNI::CallStaticLongMethodV, 2630 JNI::CallStaticLongMethodA, 2631 JNI::CallStaticFloatMethod, 2632 JNI::CallStaticFloatMethodV, 2633 JNI::CallStaticFloatMethodA, 2634 JNI::CallStaticDoubleMethod, 2635 JNI::CallStaticDoubleMethodV, 2636 JNI::CallStaticDoubleMethodA, 2637 JNI::CallStaticVoidMethod, 2638 JNI::CallStaticVoidMethodV, 2639 JNI::CallStaticVoidMethodA, 2640 JNI::GetStaticFieldID, 2641 JNI::GetStaticObjectField, 2642 JNI::GetStaticBooleanField, 2643 JNI::GetStaticByteField, 2644 JNI::GetStaticCharField, 2645 JNI::GetStaticShortField, 2646 JNI::GetStaticIntField, 2647 JNI::GetStaticLongField, 2648 JNI::GetStaticFloatField, 2649 JNI::GetStaticDoubleField, 2650 JNI::SetStaticObjectField, 2651 JNI::SetStaticBooleanField, 2652 JNI::SetStaticByteField, 2653 JNI::SetStaticCharField, 2654 JNI::SetStaticShortField, 2655 JNI::SetStaticIntField, 2656 JNI::SetStaticLongField, 2657 JNI::SetStaticFloatField, 2658 JNI::SetStaticDoubleField, 2659 JNI::NewString, 2660 JNI::GetStringLength, 2661 JNI::GetStringChars, 2662 JNI::ReleaseStringChars, 2663 JNI::NewStringUTF, 2664 JNI::GetStringUTFLength, 2665 JNI::GetStringUTFChars, 2666 JNI::ReleaseStringUTFChars, 2667 JNI::GetArrayLength, 2668 JNI::NewObjectArray, 2669 JNI::GetObjectArrayElement, 2670 JNI::SetObjectArrayElement, 2671 JNI::NewBooleanArray, 2672 JNI::NewByteArray, 2673 JNI::NewCharArray, 2674 JNI::NewShortArray, 2675 JNI::NewIntArray, 2676 JNI::NewLongArray, 2677 JNI::NewFloatArray, 2678 JNI::NewDoubleArray, 2679 JNI::GetBooleanArrayElements, 2680 JNI::GetByteArrayElements, 2681 JNI::GetCharArrayElements, 2682 JNI::GetShortArrayElements, 2683 JNI::GetIntArrayElements, 2684 JNI::GetLongArrayElements, 2685 JNI::GetFloatArrayElements, 2686 JNI::GetDoubleArrayElements, 2687 JNI::ReleaseBooleanArrayElements, 2688 JNI::ReleaseByteArrayElements, 2689 JNI::ReleaseCharArrayElements, 2690 JNI::ReleaseShortArrayElements, 2691 JNI::ReleaseIntArrayElements, 2692 JNI::ReleaseLongArrayElements, 2693 JNI::ReleaseFloatArrayElements, 2694 JNI::ReleaseDoubleArrayElements, 2695 JNI::GetBooleanArrayRegion, 2696 JNI::GetByteArrayRegion, 2697 JNI::GetCharArrayRegion, 2698 JNI::GetShortArrayRegion, 2699 JNI::GetIntArrayRegion, 2700 JNI::GetLongArrayRegion, 2701 JNI::GetFloatArrayRegion, 2702 JNI::GetDoubleArrayRegion, 2703 JNI::SetBooleanArrayRegion, 2704 JNI::SetByteArrayRegion, 2705 JNI::SetCharArrayRegion, 2706 JNI::SetShortArrayRegion, 2707 JNI::SetIntArrayRegion, 2708 JNI::SetLongArrayRegion, 2709 JNI::SetFloatArrayRegion, 2710 JNI::SetDoubleArrayRegion, 2711 JNI::RegisterNatives, 2712 JNI::UnregisterNatives, 2713 JNI::MonitorEnter, 2714 JNI::MonitorExit, 2715 JNI::GetJavaVM, 2716 JNI::GetStringRegion, 2717 JNI::GetStringUTFRegion, 2718 JNI::GetPrimitiveArrayCritical, 2719 JNI::ReleasePrimitiveArrayCritical, 2720 JNI::GetStringCritical, 2721 JNI::ReleaseStringCritical, 2722 JNI::NewWeakGlobalRef, 2723 JNI::DeleteWeakGlobalRef, 2724 JNI::ExceptionCheck, 2725 JNI::NewDirectByteBuffer, 2726 JNI::GetDirectBufferAddress, 2727 JNI::GetDirectBufferCapacity, 2728 JNI::GetObjectRefType, 2729}; 2730 2731const JNINativeInterface* GetJniNativeInterface() { 2732 return &gJniNativeInterface; 2733} 2734 2735void (*gJniSleepForeverStub[])() = { 2736 nullptr, // reserved0. 2737 nullptr, // reserved1. 2738 nullptr, // reserved2. 2739 nullptr, // reserved3. 2740 SleepForever, 2741 SleepForever, 2742 SleepForever, 2743 SleepForever, 2744 SleepForever, 2745 SleepForever, 2746 SleepForever, 2747 SleepForever, 2748 SleepForever, 2749 SleepForever, 2750 SleepForever, 2751 SleepForever, 2752 SleepForever, 2753 SleepForever, 2754 SleepForever, 2755 SleepForever, 2756 SleepForever, 2757 SleepForever, 2758 SleepForever, 2759 SleepForever, 2760 SleepForever, 2761 SleepForever, 2762 SleepForever, 2763 SleepForever, 2764 SleepForever, 2765 SleepForever, 2766 SleepForever, 2767 SleepForever, 2768 SleepForever, 2769 SleepForever, 2770 SleepForever, 2771 SleepForever, 2772 SleepForever, 2773 SleepForever, 2774 SleepForever, 2775 SleepForever, 2776 SleepForever, 2777 SleepForever, 2778 SleepForever, 2779 SleepForever, 2780 SleepForever, 2781 SleepForever, 2782 SleepForever, 2783 SleepForever, 2784 SleepForever, 2785 SleepForever, 2786 SleepForever, 2787 SleepForever, 2788 SleepForever, 2789 SleepForever, 2790 SleepForever, 2791 SleepForever, 2792 SleepForever, 2793 SleepForever, 2794 SleepForever, 2795 SleepForever, 2796 SleepForever, 2797 SleepForever, 2798 SleepForever, 2799 SleepForever, 2800 SleepForever, 2801 SleepForever, 2802 SleepForever, 2803 SleepForever, 2804 SleepForever, 2805 SleepForever, 2806 SleepForever, 2807 SleepForever, 2808 SleepForever, 2809 SleepForever, 2810 SleepForever, 2811 SleepForever, 2812 SleepForever, 2813 SleepForever, 2814 SleepForever, 2815 SleepForever, 2816 SleepForever, 2817 SleepForever, 2818 SleepForever, 2819 SleepForever, 2820 SleepForever, 2821 SleepForever, 2822 SleepForever, 2823 SleepForever, 2824 SleepForever, 2825 SleepForever, 2826 SleepForever, 2827 SleepForever, 2828 SleepForever, 2829 SleepForever, 2830 SleepForever, 2831 SleepForever, 2832 SleepForever, 2833 SleepForever, 2834 SleepForever, 2835 SleepForever, 2836 SleepForever, 2837 SleepForever, 2838 SleepForever, 2839 SleepForever, 2840 SleepForever, 2841 SleepForever, 2842 SleepForever, 2843 SleepForever, 2844 SleepForever, 2845 SleepForever, 2846 SleepForever, 2847 SleepForever, 2848 SleepForever, 2849 SleepForever, 2850 SleepForever, 2851 SleepForever, 2852 SleepForever, 2853 SleepForever, 2854 SleepForever, 2855 SleepForever, 2856 SleepForever, 2857 SleepForever, 2858 SleepForever, 2859 SleepForever, 2860 SleepForever, 2861 SleepForever, 2862 SleepForever, 2863 SleepForever, 2864 SleepForever, 2865 SleepForever, 2866 SleepForever, 2867 SleepForever, 2868 SleepForever, 2869 SleepForever, 2870 SleepForever, 2871 SleepForever, 2872 SleepForever, 2873 SleepForever, 2874 SleepForever, 2875 SleepForever, 2876 SleepForever, 2877 SleepForever, 2878 SleepForever, 2879 SleepForever, 2880 SleepForever, 2881 SleepForever, 2882 SleepForever, 2883 SleepForever, 2884 SleepForever, 2885 SleepForever, 2886 SleepForever, 2887 SleepForever, 2888 SleepForever, 2889 SleepForever, 2890 SleepForever, 2891 SleepForever, 2892 SleepForever, 2893 SleepForever, 2894 SleepForever, 2895 SleepForever, 2896 SleepForever, 2897 SleepForever, 2898 SleepForever, 2899 SleepForever, 2900 SleepForever, 2901 SleepForever, 2902 SleepForever, 2903 SleepForever, 2904 SleepForever, 2905 SleepForever, 2906 SleepForever, 2907 SleepForever, 2908 SleepForever, 2909 SleepForever, 2910 SleepForever, 2911 SleepForever, 2912 SleepForever, 2913 SleepForever, 2914 SleepForever, 2915 SleepForever, 2916 SleepForever, 2917 SleepForever, 2918 SleepForever, 2919 SleepForever, 2920 SleepForever, 2921 SleepForever, 2922 SleepForever, 2923 SleepForever, 2924 SleepForever, 2925 SleepForever, 2926 SleepForever, 2927 SleepForever, 2928 SleepForever, 2929 SleepForever, 2930 SleepForever, 2931 SleepForever, 2932 SleepForever, 2933 SleepForever, 2934 SleepForever, 2935 SleepForever, 2936 SleepForever, 2937 SleepForever, 2938 SleepForever, 2939 SleepForever, 2940 SleepForever, 2941 SleepForever, 2942 SleepForever, 2943 SleepForever, 2944 SleepForever, 2945 SleepForever, 2946 SleepForever, 2947 SleepForever, 2948 SleepForever, 2949 SleepForever, 2950 SleepForever, 2951 SleepForever, 2952 SleepForever, 2953 SleepForever, 2954 SleepForever, 2955 SleepForever, 2956 SleepForever, 2957 SleepForever, 2958 SleepForever, 2959 SleepForever, 2960 SleepForever, 2961 SleepForever, 2962 SleepForever, 2963 SleepForever, 2964 SleepForever, 2965 SleepForever, 2966 SleepForever, 2967 SleepForever, 2968 SleepForever, 2969}; 2970 2971const JNINativeInterface* GetRuntimeShutdownNativeInterface() { 2972 return reinterpret_cast<JNINativeInterface*>(&gJniSleepForeverStub); 2973} 2974 2975void RegisterNativeMethods(JNIEnv* env, const char* jni_class_name, const JNINativeMethod* methods, 2976 jint method_count) { 2977 ScopedLocalRef<jclass> c(env, env->FindClass(jni_class_name)); 2978 if (c.get() == nullptr) { 2979 LOG(FATAL) << "Couldn't find class: " << jni_class_name; 2980 } 2981 JNI::RegisterNativeMethods(env, c.get(), methods, method_count, false); 2982} 2983 2984} // namespace art 2985 2986std::ostream& operator<<(std::ostream& os, const jobjectRefType& rhs) { 2987 switch (rhs) { 2988 case JNIInvalidRefType: 2989 os << "JNIInvalidRefType"; 2990 return os; 2991 case JNILocalRefType: 2992 os << "JNILocalRefType"; 2993 return os; 2994 case JNIGlobalRefType: 2995 os << "JNIGlobalRefType"; 2996 return os; 2997 case JNIWeakGlobalRefType: 2998 os << "JNIWeakGlobalRefType"; 2999 return os; 3000 default: 3001 LOG(::art::FATAL) << "jobjectRefType[" << static_cast<int>(rhs) << "]"; 3002 UNREACHABLE(); 3003 } 3004} 3005