diff options
| author | 2015-05-28 22:47:58 +0000 | |
|---|---|---|
| committer | 2015-05-28 22:47:58 +0000 | |
| commit | 24c24d43f53224bf41a41eb214c5256dda93668d (patch) | |
| tree | fc7cc7cdb1dc9ad5003c5c0ac3a65e8511d19795 /runtime/java_vm_ext.cc | |
| parent | 023e6f6d67d6ab520e194d142f3adaafb6e3a11d (diff) | |
| parent | 83c81955bfbfe8fbe6daf215ca73e436747e3e60 (diff) | |
Merge "Fix updating of JNI references for String.<init>."
Diffstat (limited to 'runtime/java_vm_ext.cc')
| -rw-r--r-- | runtime/java_vm_ext.cc | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/runtime/java_vm_ext.cc b/runtime/java_vm_ext.cc index b795d72a6a..3142089862 100644 --- a/runtime/java_vm_ext.cc +++ b/runtime/java_vm_ext.cc @@ -562,6 +562,11 @@ mirror::Object* JavaVMExt::DecodeGlobal(Thread* self, IndirectRef ref) { return globals_.SynchronizedGet(self, &globals_lock_, ref); } +void JavaVMExt::UpdateGlobal(Thread* self, IndirectRef ref, mirror::Object* result) { + WriterMutexLock mu(self, globals_lock_); + globals_.Update(ref, result); +} + mirror::Object* JavaVMExt::DecodeWeakGlobal(Thread* self, IndirectRef ref) { MutexLock mu(self, weak_globals_lock_); while (UNLIKELY(!allow_new_weak_globals_)) { @@ -570,6 +575,11 @@ mirror::Object* JavaVMExt::DecodeWeakGlobal(Thread* self, IndirectRef ref) { return weak_globals_.Get(ref); } +void JavaVMExt::UpdateWeakGlobal(Thread* self, IndirectRef ref, mirror::Object* result) { + MutexLock mu(self, weak_globals_lock_); + weak_globals_.Update(ref, result); +} + void JavaVMExt::DumpReferenceTables(std::ostream& os) { Thread* self = Thread::Current(); { |