diff options
author | 2016-11-24 13:03:57 +0000 | |
---|---|---|
committer | 2016-11-24 13:03:57 +0000 | |
commit | 09ded9201fbeec605b12741ae255663c14bda225 (patch) | |
tree | c0276a06f8b6dba35e843098a05be326c8f5e2ac /runtime/class_table.cc | |
parent | 25dcbad4462ea7279ee2bbe0884abc25bdfac77a (diff) |
Revert "Revert "Revert "Make sure that const-class linkage is preserved."""
626-const-class-linking is failing (spurious wakeups?)
970-iface-super-resolution-gen is failing:
dex2oatd F 11-24 10:57:16 6410 6410 image_writer.cc:1144]
Check failed: !IsBootClassLoaderClass(as_klass)
java.lang.Class<java.lang.NoSuchMethodError>
Bug: 30627598
This reverts commit 25dcbad4462ea7279ee2bbe0884abc25bdfac77a.
Change-Id: Ie010169bdde45e6ccf2e04a521da4682bd817114
Diffstat (limited to 'runtime/class_table.cc')
-rw-r--r-- | runtime/class_table.cc | 22 |
1 files changed, 6 insertions, 16 deletions
diff --git a/runtime/class_table.cc b/runtime/class_table.cc index 81cdce57a8..0fcce6b307 100644 --- a/runtime/class_table.cc +++ b/runtime/class_table.cc @@ -83,29 +83,18 @@ mirror::Class* ClassTable::UpdateClass(const char* descriptor, mirror::Class* kl #pragma clang diagnostic pop // http://b/31104323 -size_t ClassTable::CountDefiningLoaderClasses(ObjPtr<mirror::ClassLoader> defining_loader, - const ClassSet& set) const { - size_t count = 0; - for (const GcRoot<mirror::Class>& klass : set) { - if (klass.Read()->GetClassLoader() == defining_loader) { - ++count; - } - } - return count; -} - -size_t ClassTable::NumZygoteClasses(ObjPtr<mirror::ClassLoader> defining_loader) const { +size_t ClassTable::NumZygoteClasses() const { ReaderMutexLock mu(Thread::Current(), lock_); size_t sum = 0; for (size_t i = 0; i < classes_.size() - 1; ++i) { - sum += CountDefiningLoaderClasses(defining_loader, classes_[i]); + sum += classes_[i].Size(); } return sum; } -size_t ClassTable::NumNonZygoteClasses(ObjPtr<mirror::ClassLoader> defining_loader) const { +size_t ClassTable::NumNonZygoteClasses() const { ReaderMutexLock mu(Thread::Current(), lock_); - return CountDefiningLoaderClasses(defining_loader, classes_.back()); + return classes_.back().Size(); } mirror::Class* ClassTable::Lookup(const char* descriptor, size_t hash) { @@ -113,7 +102,7 @@ mirror::Class* ClassTable::Lookup(const char* descriptor, size_t hash) { for (ClassSet& class_set : classes_) { auto it = class_set.FindWithHash(descriptor, hash); if (it != class_set.end()) { - return it->Read(); + return it->Read(); } } return nullptr; @@ -153,6 +142,7 @@ uint32_t ClassTable::ClassDescriptorHashEquals::operator()(const GcRoot<mirror:: bool ClassTable::ClassDescriptorHashEquals::operator()(const GcRoot<mirror::Class>& a, const GcRoot<mirror::Class>& b) const { + DCHECK_EQ(a.Read()->GetClassLoader(), b.Read()->GetClassLoader()); std::string temp; return a.Read()->DescriptorEquals(b.Read()->GetDescriptor(&temp)); } |