diff options
Diffstat (limited to 'runtime/class_linker.cc')
| -rw-r--r-- | runtime/class_linker.cc | 39 | 
1 files changed, 19 insertions, 20 deletions
| diff --git a/runtime/class_linker.cc b/runtime/class_linker.cc index 7aa28d36be..48d31a4c3e 100644 --- a/runtime/class_linker.cc +++ b/runtime/class_linker.cc @@ -3341,13 +3341,12 @@ mirror::DexCache* ClassLinker::FindDexCacheLocked(Thread* self,    for (const DexCacheData& data : dex_caches_) {      // Avoid decoding (and read barriers) other unrelated dex caches.      if (data.dex_file == &dex_file) { -      mirror::DexCache* dex_cache = -          down_cast<mirror::DexCache*>(self->DecodeJObject(data.weak_root)); +      ObjPtr<mirror::DexCache> dex_cache = +          ObjPtr<mirror::DexCache>::DownCast(self->DecodeJObject(data.weak_root));        if (dex_cache != nullptr) { -        return dex_cache; -      } else { -        break; +        return dex_cache.Ptr();        } +      break;      }    }    if (allow_failure) { @@ -3356,7 +3355,8 @@ mirror::DexCache* ClassLinker::FindDexCacheLocked(Thread* self,    std::string location(dex_file.GetLocation());    // Failure, dump diagnostic and abort.    for (const DexCacheData& data : dex_caches_) { -    mirror::DexCache* dex_cache = down_cast<mirror::DexCache*>(self->DecodeJObject(data.weak_root)); +    ObjPtr<mirror::DexCache> dex_cache = +        ObjPtr<mirror::DexCache>::DownCast(self->DecodeJObject(data.weak_root));      if (dex_cache != nullptr) {        LOG(ERROR) << "Registered dex file " << dex_cache->GetDexFile()->GetLocation();      } @@ -3370,7 +3370,7 @@ void ClassLinker::FixupDexCaches(ArtMethod* resolution_method) {    ReaderMutexLock mu(self, dex_lock_);    for (const DexCacheData& data : dex_caches_) {      if (!self->IsJWeakCleared(data.weak_root)) { -      mirror::DexCache* dex_cache = down_cast<mirror::DexCache*>( +      ObjPtr<mirror::DexCache> dex_cache = ObjPtr<mirror::DexCache>::DownCast(            self->DecodeJObject(data.weak_root));        if (dex_cache != nullptr) {          dex_cache->Fixup(resolution_method, image_pointer_size_); @@ -4297,11 +4297,11 @@ mirror::Class* ClassLinker::CreateProxyClass(ScopedObjectAccessAlreadyRunnable&    CHECK_EQ(interfaces_sfield.GetDeclaringClass(), klass.Get());    interfaces_sfield.SetObject<false>(        klass.Get(), -      soa.Decode<mirror::ObjectArray<mirror::Class>>(interfaces).Ptr()); +      soa.Decode<mirror::ObjectArray<mirror::Class>>(interfaces));    CHECK_EQ(throws_sfield.GetDeclaringClass(), klass.Get());    throws_sfield.SetObject<false>(        klass.Get(), -      soa.Decode<mirror::ObjectArray<mirror::ObjectArray<mirror::Class>>>(throws).Ptr()); +      soa.Decode<mirror::ObjectArray<mirror::ObjectArray<mirror::Class>>>(throws));    {      // Lock on klass is released. Lock new class object. @@ -4331,9 +4331,9 @@ mirror::Class* ClassLinker::CreateProxyClass(ScopedObjectAccessAlreadyRunnable&      CHECK_EQ(PrettyField(klass->GetStaticField(1)), throws_field_name);      CHECK_EQ(klass.Get()->GetInterfaces(), -             soa.Decode<mirror::ObjectArray<mirror::Class>>(interfaces).Ptr()); +             soa.Decode<mirror::ObjectArray<mirror::Class>>(interfaces));      CHECK_EQ(klass.Get()->GetThrows(), -             soa.Decode<mirror::ObjectArray<mirror::ObjectArray<mirror::Class>>>(throws).Ptr()); +             soa.Decode<mirror::ObjectArray<mirror::ObjectArray<mirror::Class>>>(throws));    }    return klass.Get();  } @@ -8304,7 +8304,7 @@ jobject ClassLinker::CreatePathClassLoader(Thread* self,    // Make it a global ref and return.    ScopedLocalRef<jobject> local_ref( -      soa.Env(), soa.Env()->AddLocalReference<jobject>(MakeObjPtr(h_path_class_loader.Get()))); +      soa.Env(), soa.Env()->AddLocalReference<jobject>(h_path_class_loader.Get()));    return soa.Env()->NewGlobalRef(local_ref.get());  } @@ -8341,9 +8341,10 @@ void ClassLinker::VisitClassLoaders(ClassLoaderVisitor* visitor) const {    Thread* const self = Thread::Current();    for (const ClassLoaderData& data : class_loaders_) {      // Need to use DecodeJObject so that we get null for cleared JNI weak globals. -    auto* const class_loader = down_cast<mirror::ClassLoader*>(self->DecodeJObject(data.weak_root)); +    ObjPtr<mirror::ClassLoader> class_loader = ObjPtr<mirror::ClassLoader>::DownCast( +        self->DecodeJObject(data.weak_root));      if (class_loader != nullptr) { -      visitor->Visit(class_loader); +      visitor->Visit(class_loader.Ptr());      }    }  } @@ -8371,8 +8372,8 @@ void ClassLinker::CleanupClassLoaders() {      for (auto it = class_loaders_.begin(); it != class_loaders_.end(); ) {        const ClassLoaderData& data = *it;        // Need to use DecodeJObject so that we get null for cleared JNI weak globals. -      auto* const class_loader = -          down_cast<mirror::ClassLoader*>(self->DecodeJObject(data.weak_root)); +      ObjPtr<mirror::ClassLoader> class_loader = +          ObjPtr<mirror::ClassLoader>::DownCast(self->DecodeJObject(data.weak_root));        if (class_loader != nullptr) {          ++it;        } else { @@ -8400,8 +8401,7 @@ std::set<DexCacheResolvedClasses> ClassLinker::GetResolvedClasses(bool ignore_bo      if (soa.Self()->IsJWeakCleared(data.weak_root)) {        continue;      } -    mirror::DexCache* dex_cache = -        down_cast<mirror::DexCache*>(soa.Self()->DecodeJObject(data.weak_root)); +    ObjPtr<mirror::DexCache> dex_cache = soa.Decode<mirror::DexCache>(data.weak_root);      if (dex_cache == nullptr) {        continue;      } @@ -8468,8 +8468,7 @@ std::unordered_set<std::string> ClassLinker::GetClassDescriptorsForProfileKeys(    ReaderMutexLock mu(self, *DexLock());    for (const ClassLinker::DexCacheData& data : GetDexCachesData()) {      if (!self->IsJWeakCleared(data.weak_root)) { -      mirror::DexCache* dex_cache = -          down_cast<mirror::DexCache*>(soa.Self()->DecodeJObject(data.weak_root)); +      ObjPtr<mirror::DexCache> dex_cache = soa.Decode<mirror::DexCache>(data.weak_root);        if (dex_cache != nullptr) {          const DexFile* dex_file = dex_cache->GetDexFile();          // There could be duplicates if two dex files with the same location are mapped. |