diff options
| author | 2013-10-18 15:42:20 -0700 | |
|---|---|---|
| committer | 2013-10-20 14:55:26 -0700 | |
| commit | 1eb512d33f94d1dd7ea38263307ba0f7a0dfa653 (patch) | |
| tree | b4d4d9b16013ab90fb4b40d23013d7ef44bb5852 /runtime/native/java_lang_Object.cc | |
| parent | b917ea1a62aa0ab8eca3f689ef64b5be34e11abb (diff) | |
Fast JNI support.
Use a modifier to signal a native method is a fast JNI method. If the
modifier is set then don't perform runnable transitions.
Change-Id: I7835b4d837bfdd1cb8e2d54b919c0d5e6cf90499
Diffstat (limited to 'runtime/native/java_lang_Object.cc')
| -rw-r--r-- | runtime/native/java_lang_Object.cc | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/runtime/native/java_lang_Object.cc b/runtime/native/java_lang_Object.cc index 5db7a330a8..4768f48d9c 100644 --- a/runtime/native/java_lang_Object.cc +++ b/runtime/native/java_lang_Object.cc @@ -16,7 +16,7 @@ #include "jni_internal.h" #include "mirror/object-inl.h" -#include "scoped_thread_state_change.h" +#include "scoped_fast_native_object_access.h" // TODO: better support for overloading. #undef NATIVE_METHOD @@ -26,41 +26,41 @@ namespace art { static jobject Object_internalClone(JNIEnv* env, jobject java_this) { - ScopedObjectAccess soa(env); + ScopedFastNativeObjectAccess soa(env); mirror::Object* o = soa.Decode<mirror::Object*>(java_this); return soa.AddLocalReference<jobject>(o->Clone(soa.Self())); } static void Object_notify(JNIEnv* env, jobject java_this) { - ScopedObjectAccess soa(env); + ScopedFastNativeObjectAccess soa(env); mirror::Object* o = soa.Decode<mirror::Object*>(java_this); o->Notify(soa.Self()); } static void Object_notifyAll(JNIEnv* env, jobject java_this) { - ScopedObjectAccess soa(env); + ScopedFastNativeObjectAccess soa(env); mirror::Object* o = soa.Decode<mirror::Object*>(java_this); o->NotifyAll(soa.Self()); } static void Object_wait(JNIEnv* env, jobject java_this) { - ScopedObjectAccess soa(env); + ScopedFastNativeObjectAccess soa(env); mirror::Object* o = soa.Decode<mirror::Object*>(java_this); o->Wait(soa.Self()); } static void Object_waitJI(JNIEnv* env, jobject java_this, jlong ms, jint ns) { - ScopedObjectAccess soa(env); + ScopedFastNativeObjectAccess soa(env); mirror::Object* o = soa.Decode<mirror::Object*>(java_this); o->Wait(soa.Self(), ms, ns); } static JNINativeMethod gMethods[] = { - NATIVE_METHOD(Object, internalClone, "()Ljava/lang/Object;", internalClone), - NATIVE_METHOD(Object, notify, "()V", notify), - NATIVE_METHOD(Object, notifyAll, "()V", notifyAll), - NATIVE_METHOD(Object, wait, "()V", wait), - NATIVE_METHOD(Object, wait, "(JI)V", waitJI), + NATIVE_METHOD(Object, internalClone, "!()Ljava/lang/Object;", internalClone), + NATIVE_METHOD(Object, notify, "!()V", notify), + NATIVE_METHOD(Object, notifyAll, "!()V", notifyAll), + NATIVE_METHOD(Object, wait, "!()V", wait), + NATIVE_METHOD(Object, wait, "!(JI)V", waitJI), }; void register_java_lang_Object(JNIEnv* env) { |